اولین بار است که به اینجا می‌آیید؟ راهنمای سایت را بخوانید!
Close Sidebar
وب‌سایت پرسش و پاسخ پارسی‌لاتک جایی برای پرسش و پاسخ درباره سیستم حروف‌چینی لاتک و بسته زی‌پرشین است. در اینجا می‌توانید سوال‌های خود را بپرسید و به سوال‌های دیگران پاسخ دهید.

محبوب‌ترین برچسب‌ها

رفع خطا جدول مراجع xepersian ریاضی‌نویسی شکل فونت فهرست مطالب شماره‌گذاری منابع bidi پانویس بیب‌تک tikz تک‌لایو parsilatex بیمر اسلاید زی‌پرشین پاورقی سربرگ bibtex نماد فرمول‌نویسی رسم شکل قالب ارجاع‌دهی biditexmaker هدر ویرایشگر beamer واژه‌نامه اندازه فونت texstudio عنوان فصل ماتریس اعمال نشدن تغییرات در پی‌دی‌اف رسم جدول bidipresentation شماره صفحه حاشیه رنگ عنوان شکل اسلاید فارسی محیط قضیه گراف مکان شکل tikzpicture حروف‌چینی کد شماره فصل enumerate tabriz_thesis نمایه align زیرنویس شکل کادر itemize listings الگوریتم عدم اجرا نیم‌فاصله متن لاتین و فارسی فهرست اشکال بسته فاصله بین خطوط قالب پایان‌نامه فرمول نصب تک‌لایو فارسی‌تک hyperref شماره فرمول glossaries کپشن نمودار حروف‌چینی چندستونی فونت فارسی و انگلیسی ماکرونویسی خروجی biditools شماره پاورقی پیوست‌ فاصله‌گذاری فرمول چندضابطه‌ای لاتک سوال امتحانی subfigure extrafootnotefeatures header texmaker pdf tex biditufte-book تصویر شمارنده texlive2015 longtable زیرنویس خطا رسم نمودار شماره‌گذاری صفحات پایان نامه دیاگرام فهرست جداول میک‌تک texlive2016 تنظیم جدول kashida texworks caption اندیس lollipop iust-thesis multicol فصل‌نویسی شعر سوال چهارگزینه‌ای بولد تورفتگی آکولاد اعداد فارسی فاصله عمودی xindy چپ‌چینی اوبونتو میکروسافت ورد قاب geometry texlive fancyhdr تک لایو 2015 عنوان بخش به‌روزرسانی بسته aimc46 صفر توخالی فرمول طولانی بیرون‌زدگی کاما وسط‌چینی tcolorbox پوستر شماره گذاری فاصله سطرها نوشتافت شکست خط tex-programming فونت اعداد pgfplots قرآن tabriz-thesis ایتالیک winedt جستجوی معکوس xelatex فلش جایابی تصویر قالب کتاب پاراگراف‌بندی بازیابی اطلاعات هایپرلینک فهرست نمادها شمارنده فصل font محیط ریاضی رسم کادر جداکننده جدول طولانی فهرست تصاویر شماره‌گذاری فرمول algorithm2e فونت بولد proof equation bidipoem eps جدول افقی عکس به‌روزرسانی پانویس چندستونی کمک مالی فاصله خطوط حروف‌چینی شعر زیرشکل minipage قلم پانویس پاراگرافی ltrfootnote پیوست computeautoilg متن فارسی و انگلیسی فرمول چندخطی neveshtuft غلط‌گیری املایی تک‌پارسی پیکان لاتکس tabular baselineskip شماره قسمت قسمت عنوان جدول
11 نفر آنلاین
0 عضو و 11 مهمان در سایت حاضرند
بازدید امروز: 2442
بازدید دیروز: 36769
بازدید کل: 21207810

ارتباط لیتک با پایگاه داده برای mailing

0 رای
240 بازدید

چگونه می‌توان، همانند واژه‌پرداز Word، برای نوشتن یک نامه/متن برای چندین نفر، از خاصیت mailing در لیتک استفاده کرد؟

سوال شده تیر 6, 1400 توسط بهمن میرزاخانی (3,203 امتیاز)
برچسب گذاری دوباره تیر 6, 1400 توسط بهمن میرزاخانی

1 پاسخ

+1 رای
 
بهترین پاسخ

برای این کار می‌توان از بستهٔ datatool استفاده کرد.
فرض کنید قصد داریم به چندین شخص که مشخصات آن‌ها در فایل csv ذخیره شده است، دعوت‌نامه تهیه کنیم. برای مثال اطلاعات زیر در یک فایل csv ذخیره شده است:

enter image description here

دستور \DTLforeach* از بستهٔ datatool با فرمت کلی زیر در دسترس است:

\DTLforeache*[condition]{db name}{assign list}{text}

حالت ستاره‌دار برای استفاده از دیتابیس در حالت read only است (از اونجایی که ما قصد تغییر فایل دیتابیس رو نداریم، پس بهتره همون از حالت ستاره‌دار استفاده کنیم).
در قسمت [condition] می‌توان از عبارت‌های شرطی استفاده کرد.
در قسمت {db name} نام فایل دیتابیس رو وارد خواهیم کرد (البته برای همین هم یک دستور لازمه که در کد کمینه مشاهده می‌کنید).
در قسمت {assign list} ستون‌ها رو مشخص می‌کنیم.
و در قسمت {text} متن خودمونو می‌نویسیم به‌همراه استفاده از داده‌های فایل csv.


\begin{filecontents*}[overwrite]{data.csv}
    FirstName, LastName, City
    علی, احمدی, زنجان
    وحید, مهدیون, سلطانیه
    اصغر, محمدی, ابهر
\end{filecontents*}
\documentclass{article}
\usepackage{datatool}
\usepackage{xepersian}
\settextfont{Amiri}
\begin{document}
    \DTLloaddb{dbAddress}{data.csv} % آدرس فایل دیتابیس در این خط مشخص می‌شود
    \DTLforeach*{dbAddress}{%
        \firstName=FirstName,
        \lastName=LastName,
        \city=City}%
    {%
        \thispagestyle{empty}
        جناب
        \textbf{\firstName~\lastName}
        از
        \city،
        شما دعوت شده‌اید. تشریف بیارید لطفاً!

        \clearpage
    }
\end{document}

مثالی دیگر از راهنمای بسته برای ایجاد جدول از دیتابیس:

\begin{filecontents*}[overwrite]{studentscores.csv}
    FirstName,Surname,StudentNo,Score
    John,"Smith, Jr",102689,68
    Jane,Brown,102647,75
    Andy,Brown,103569,42
    Z\"oe,Adams,105987,52
    Roger,Brady,106872,58
    Clare,Verdon,104356,45
\end{filecontents*}
\documentclass{article}
\usepackage{datatool}
\begin{document}
    \DTLloaddb{scores}{studentscores.csv}
    \begin{table}[htbp]
        \caption{Student scores}
        \centering
        \begin{tabular}{llr}
            \bfseries First Name &
            \bfseries Surname &
            \bfseries Score (\%)%
            \DTLforeach*{scores}{%
            \firstname=FirstName,\surname=Surname,\score=Score}{%
            \\% start new row
            \firstname & \surname & \score}
        \end{tabular}
    \end{table}
\end{document}

خروجی:
enter image description here

پاسخ داده شده تیر 6, 1400 توسط بهمن میرزاخانی (3,203 امتیاز)
انتخاب شده تیر 9, 1400 توسط بهمن میرزاخانی
...