LaTeX中的表格一直是一件麻煩事斟薇,想要把可視化軟件中生成的表格導(dǎo)出成LaTeX的表格還是頗費(fèi)工夫的抢肛。我且寫(xiě)幾個(gè)大概可用的辦法僵闯。
編輯器
當(dāng)然網(wǎng)上是可以找到若干可視化編輯器的翔横。有的是網(wǎng)頁(yè)版缅刽,有的是一些簡(jiǎn)單的小軟件啊掏,比如這個(gè)
一種簡(jiǎn)單的可視化編輯器
來(lái)源:LaTable編輯器
Excel插件
格式要求一般的時(shí)候,CTAN上的這個(gè)插件是比較方便的:
插件
該插件對(duì)簡(jiǎn)單的表格能完美地生成代碼衰猛,也支持文字對(duì)齊迟蜜、合并單元格、彩色單元格等格式的轉(zhuǎn)化啡省。它不足的是在轉(zhuǎn)換的表格框線(xiàn)較多時(shí)往往不夠理想娜睛。這主要是因?yàn)樗偸前沿Q線(xiàn)畫(huà)成斷續(xù)的線(xiàn),而不會(huì)在\begin{tabular}
處的選項(xiàng)里加豎線(xiàn)卦睹。
貼一段py程序
GitHub上有人寫(xiě)過(guò)類(lèi)似的程序畦戒。不過(guò)為了適應(yīng)自己的習(xí)慣還是自己重寫(xiě)了一個(gè)玩意,來(lái)把簡(jiǎn)單的CSV文檔轉(zhuǎn)化成tex表格结序。只支持簡(jiǎn)單的方塊形表格障斋,輸出固定的格式,可以轉(zhuǎn)化科學(xué)計(jì)數(shù)法(雖然不是很完善:-|)徐鹤。當(dāng)然垃环,你可以在你的源CSV文件中寫(xiě)入\multicol
、\multirow
返敬、\diagbox
等命令遂庄,并配合適當(dāng)?shù)亩禾?hào)分隔符來(lái)實(shí)現(xiàn)合并單元格、制作表頭等功能劲赠。另外涧团,程序只接受UTF-8格式的編碼只磷。
好吧,不管怎么說(shuō)泌绣,對(duì)一個(gè)普通的實(shí)驗(yàn)報(bào)告還是可用的钮追。。
DELIMITER=","
import csv
while True:
fin = input("Please provide a text file:\n\t\t\t\t")
cap = str(input("Please give the caption of the table:\n\t\t\t\t"))
lab = str(input("Please give the label of the table:\n\t\t\t\t"))
fout = str(input("Please give a filename:\n\t\t\t\t"))
print("\\begin{table}[htbp!]\n\t\\centering\n\t\\caption{" + cap + "}\\label{tab:" + lab + "}")
s = "\\begin{table}[htbp!]\n\t\\centering\n\t\\caption{" + cap + "}\\label{tab:" + lab + "}"
with open(fin,'r',encoding='utf8') as c:
first=True
second = True
reader = csv.reader(c, delimiter=DELIMITER)
for row in reader:
if(row!=[]):
if(first):
first=False
p="\\begin{tabular}{c"
for i in range(len(row)-1):
if(i==0):
p+="||c"
else:
p+="|c"
p+="}\n\t\t\\hline\\hline"
print("\t"+p)
s = s+ "\t" + p
else:
print("\t\t\\hline")
s = s + "\t\t\\hline"
if second:
second = False
print("\t\t\\hline")
s = s + "\hline"
s = s + "\n"
r=""
for i in range(len(row)):
ifscidig = row[i].split('E')
if len(ifscidig) == 2:
base, exponent = ifscidig[0], ifscidig[1]
base0 = base
ifdec = base.split('.')
if len(ifdec) == 2:
bint, bdec = ifdec[0], ifdec[1]
elif len(ifdec) == 1:
bint, bdec = ifdec[0], ''
ifpos = exponent.split('-')
if len(ifdec) == 2:
esgn, eabs = '-', ifpos[1]
elif len(ifdec) == 1:
esgn, eabs = '', ifpos[0]
if bint.isnumeric() and bdec.isnumeric() and eabs.isnumeric():
appender = "$" + bint + '.' + bdec + "\\times 10^{" + esgn + str(int(eabs)) + "}$"
else:
appender = str(row[i])
else:
appender = str(row[i])
if i == len(row)-1:
r+=appender+"\\\\"
else:
r+=appender+" & "
print("\t\t"+r)
s = s + "\t\t" + r
print("\t\t\\hline\\hline\n\t\\end{tabular}\n\\end{table}")
s = s + "\t\t\\hline\\hline\n\t\\end{tabular}\n\\end{table}"
with open(fout+".tex",'w',encoding = 'utf8') as f:
f.write(s)
input("\nOutput written in \'" + fout + ".tex\'. \nTo use the result in a tex file, write \'\\input{" + fout + ".tex}\'.")
示例
csv文件:
偏振片方位角/$^{\circ}$,73.9,164.5,255.4,345.0
譜線(xiàn)數(shù)目,3,6,3,6
譜線(xiàn)類(lèi)型,$\uppi$,$\upsigma$,$\uppi$,$\upsigma$
運(yùn)行:
輸出文件:
\begin{table}[htbp!]
\centering
\caption{汞綠線(xiàn)塞曼分裂譜線(xiàn)的偏振特性}\label{tab:gp} \begin{tabular}{c||c|c|c|c}
\hline\hline
偏振片方位角/$^{\circ}$ & 73.9 & 164.5 & 255.4 & 345.0\\ \hline\hline
譜線(xiàn)數(shù)目 & 3 & 6 & 3 & 6\\ \hline
譜線(xiàn)類(lèi)型 & $\uppi$ & $\upsigma$ & $\uppi$ & $\upsigma$\\ \hline\hline
\end{tabular}
\end{table}
編譯結(jié)果:
不過(guò)呢阿迈,更復(fù)雜的表格最終還是依賴(lài)手打的元媚,期待某天可以找到真正的自動(dòng)轉(zhuǎn)化軟件。苗沧。
一個(gè)比較復(fù)雜的表