اولین بار است که به اینجا می‌آیید؟ راهنمای سایت را بخوانید!
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 longtable تصویر شمارنده texlive2015 زیرنویس خطا رسم نمودار شماره‌گذاری صفحات پایان نامه دیاگرام فهرست جداول میک‌تک texlive2016 تنظیم جدول آکولاد kashida texworks caption اندیس lollipop iust-thesis multicol فصل‌نویسی شعر سوال چهارگزینه‌ای بولد تورفتگی اعداد فارسی فاصله عمودی xindy چپ‌چینی اوبونتو میکروسافت ورد قاب geometry texlive fancyhdr وسط‌چینی تک لایو 2015 عنوان بخش شماره گذاری به‌روزرسانی بسته aimc46 صفر توخالی فرمول طولانی بیرون‌زدگی xelatex کاما tcolorbox پوستر فاصله سطرها نوشتافت شکست خط tex-programming فونت اعداد pgfplots قرآن tabriz-thesis ایتالیک winedt جستجوی معکوس فلش جایابی تصویر قالب کتاب پاراگراف‌بندی بازیابی اطلاعات هایپرلینک فهرست نمادها شمارنده فصل font محیط ریاضی رسم کادر جداکننده جدول طولانی فهرست تصاویر شماره‌گذاری فرمول algorithm2e فونت بولد proof equation bidipoem eps جدول افقی عکس به‌روزرسانی پانویس چندستونی کمک مالی فاصله خطوط حروف‌چینی شعر زیرشکل minipage قلم پانویس پاراگرافی ltrfootnote پیوست computeautoilg متن فارسی و انگلیسی فرمول چندخطی neveshtuft غلط‌گیری املایی تک‌پارسی پیکان لاتکس tabular baselineskip شماره قسمت قسمت عنوان جدول
30 نفر آنلاین
0 عضو و 30 مهمان در سایت حاضرند
بازدید امروز: 94676
بازدید دیروز: 73184
بازدید کل: 25259765

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

0 رای
367 بازدید

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

سوال شده تیر 6, 1400 توسط بهمن میرزاخانی (3,248 امتیاز)
برچسب گذاری دوباره تیر 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,248 امتیاز)
انتخاب شده تیر 9, 1400 توسط بهمن میرزاخانی
...