是否可以使用终端命令来操作 LibreOffice calc(电子表格)中的数据。我有一个电子表格,其中包含大量 csv 格式的数据,我想从终端进行数据操作,而无需打开 libreoffice。
csv 包含 5 列
columns
A B C D E
其中我想要删除 B、C 和 E 列中的数据,然后将数据从 D 列复制到 B 列。
然后在 C5 位置的空白 C 列中,我想添加这个方程 =( B5*($B1/$A1)
),并从 C6 开始直到数据末尾 ( C6:Cn
),我想运行此代码=((A6+B6)*C5)
仅使用终端命令就能完成这些操作吗?
这是csv 文件
答案1
最简单的方法是将 libreoffice 中的文件保存为标准 CSV 格式,通常使用“,”作为分隔符,并在 (”) 中引用文本,并以此格式保存公式。您的数据应如下所示:
7,444,5555,99,"bcdef"
22,444,5555,99,"bcdef"
然后,您可以使用简单的 awk 命令(例如)来处理它。您可以在字段中包含以“=”开头的公式。例如,
5,99,"=(B5*(B1/A1))"
然后,您在 libreoffice 中读取此 .csv 文件。通常它应该会保留公式。
以下是一个例子awk脚本将文件操作example.csv
成文件并new.csv
按照您的指定替换列,其中 Cn 的公式为 ((An+Bn)*C5)。
awk -F, <example.csv >new.csv '
NR<=4 { printf "%s,%s\n",$1,$4 }
NR==5 { printf "%s,%s,\"%s\"\n",$1,$4,"=(B5*(B1/A1))" }
NR>=6 { printf "%s,%s,\"=((A%d+B%d)*C%d)\"\n",$1,$4,NR,NR,5; }
'
您可以使用以下方法将 new.csv 转换为 .ods:
libreoffice --convert-to ods new.csv
如果您的数据包含“,”和(”),则需要更改各处使用的分隔符。
(要将带有公式的单元格保存为 csv,请执行以下操作:另存为,文件类型为文本 CSV,勾选编辑过滤器设置,保存,字段选项:勾选保存单元格公式,勾选引用所有文本单元格。)
我在看您的示例 data.csv 文件并在我的讨论中将其复制到 example.csv。我删除了第 1 行“A、B、C、D、E”(列标题),因为这使得更难解释文件中的行号与表中的行之间的对应关系。我使用这个 sed 命令执行了此操作:
sed -i '1{/A,B,C/d}' example.csv
如果需要的话,您可以在最后恢复标题:
sed -i '1i\A,B,C' new.csv
如果您想在 libreoffice 之外实际执行公式运算您可以在 awk 中按如下方式执行此操作。awk 一次读取一行数据并执行 {} 中的每个命令。$1 设置为第 1 列,依此类推(如 -F,表示列以“,”分隔)。我们可以将这些值保存在按行号索引的数组中,例如 A[NR]=$1 保存第 1 列(第 A 列)天然橡胶(当前行)在数组 A 中。C[NR] 可以设置为结果计算。然后我们可以在后面的行中再次使用这些:
awk -F, <example.csv >new.csv '
{ A[NR]=$1; B[NR]=$4 }
NR<=4 { printf "%s,%s\n",A[NR],B[NR] }
NR==5 { C[NR] = B[5]*(B[1]/A[1]); printf "%s,%s,%s\n",A[NR],B[NR],C[NR] }
NR>=6 { C[NR] = (A[NR]+B[NR])*C[5]; printf "%s,%s,%s\n",A[NR],B[NR],C[NR] }
'