包含帶有有空欄位的 csv 資料的 LaTeX 文檔

包含帶有有空欄位的 csv 資料的 LaTeX 文檔

我正在用乳膠寫一封套用信函。位址來自外部資料來源。問題是資料來源中出現空白欄位(實際上非常頻繁)(見下文)。因此,由於\def\chopline#1,#2,#3,#4,#5,#6,#7,#8 \\該行\expandafter\chopline\zeile\\以某種方式期望逗號後面至少有一個字元並消耗它。如果一個字段中沒有數據,它只會「吃掉」逗號並包含下一個數據字段,從而導致一團糟。任何有關如何緩解問題的建議都會有所幫助。

另外,我前段時間複製了這個例子,並沒有理解所有命令及其含義。我的印像是我使用的結構相當舊,可能不是實現我想要的行為的最安全的方式。我可以使用 LuaLaTeX 提供的哪些更進階的工具來改進實作套用信函的程式碼?

這是代碼:

\documentclass{scrlttr2}

\usepackage{etoolbox}

\usepackage{fontspec}
\setmainfont{Linux Libertine O}
\setsansfont{Linux Biolinum O}
\setmonofont{Linux Libertine Mono O}

\def\chopline#1,#2,#3,#4,#5,#6,#7,#8 \\{
    \def\lastname{#1}
    \def\firstname{#2}
    \def\fanilyname{#3}
    \def\addrsuppa{#4}
    \def\street{#5}
    \def\addrsuppb{#6}
    \def\postcode{#7}
    \def\town{#8}
}

\newif\ifmore \moretrue

\begin{document}

\setkomavar{subject}{Subject}

\newread\quelle
\openin\quelle=../teilnehmer.csv

\read\quelle to \zeile

\loop
    \read\quelle to \zeile
    \ifeof\quelle
        \global\morefalse
    \else
        \expandafter\chopline\zeile\\
        \begin{letter}{\firstname\ \lastname \\
        \postcode\ \town}

        \opening{Sehr geehrte Familie \lastname,}

        [content]

        \closing{Best regards}

        \end{letter}  
    \fi
\ifmore\repeat

\closein\quelle

\end{document}

這是資料來源(包含一些虛擬資料):

last_name,first_name,family_name,address_supplement_1,street,address_supplement_2,postcode,town,telephone_1,telephone_2,mail
Barnes,Helen,,Apartment 3,Potsdamer Platz 10,Neukölln,99823,Görlitz,3714 2487824,8797 9717692,[email protected]
Thomas,Brandon,,,Dorfstraße 34d,,20903,Aachen,9214 3252403,,[email protected]
Kelley,Juan,,,Hauptstraße 11,,00495,Hamburg,6265 9683011,6263 6235169,[email protected]
Fisher,Anne,,,Berliner Straße 99,,39856,Oldenburg,0666 6226586,7917 5816244,
Sanchez,Martha,Miller,,Mittelweg 23,,11932,Leverkusen,3728 6123496,,[email protected]
Morrison,Daniel,,,Schulstraße 8,,11943,Neustadt,9589 2520624,
Brown,David,Clark,Room 42,Bahnhofstraße 12,Amorbach,12821,Neckarsulm,9304 3674329,,[email protected]
Graham,Frank,,,Lindenallee 19,,32956,Neustadt,,,[email protected]
Price,Douglas,,,Mühlweg 5e,,04923,Neustadt,7934 4700638,7689 9255281,[email protected]

答案1

這是一個使用的解決方案datatool(假設數據在 中test.csv,酌情更改):

\documentclass{scrlttr2}

\usepackage{etoolbox}

\usepackage{fontspec}
\setmainfont{Liberation Sans}% (I don't have the fonts from the original MWE)

\usepackage{datatool}

\DTLloaddb{mydata}{test.csv}

\begin{document}
\setkomavar{subject}{Subject}

\DTLforeach*{mydata}%
 {\LastName=last_name,\FirstName=first_name,%
  \AddrI=address_supplement_1,\Street=street,%
  \AddrII=address_supplement_2,\PostCode=postcode,\Town=town}%
 {%
    \begin{letter}{\FirstName\ \LastName\\%
    \DTLifnullorempty{\AddrI}{}{\AddrI\\}%
    \DTLifnullorempty{\Street}{}{\Street\\}%
    \DTLifnullorempty{\AddrII}{}{\AddrII\\}%
    \PostCode\\\Town}

    \opening{Sehr geehrt Familie \LastName,}

    [content]

    \closing{Best regards}
    \end{letter}
 }

\end{document}

相關內容