Eka*_*Eka 2 command-line bash libreoffice
是否可以使用终端命令操作 LibreOffice calc(电子表格)中的数据。我有一个包含大量 csv 格式数据的电子表格,我想在不打开 libreoffice 的情况下从终端进行数据操作。
csv 包含 5 列
columns
A B C D E
Run Code Online (Sandbox Code Playgroud)
我想删除 B、C 和 E 列中的数据,然后将数据从 D 列复制到 B 列。
然后在 C5 位置的空 C 列中我想添加这个方程 =( B5*($B1/$A1)
) 并从 C6 开始直到数据结束 ( C6:Cn
) 我想运行此代码=((A6+B6)*C5)
仅使用终端命令就可以完成这种操作吗?
这是csv 文件
最简单的方法是以标准化 CSV 格式保存 libreoffice 中的文件,通常使用“,”作为分隔符并在 (") 中引用文本,然后保存公式。您的数据应如下所示:
7,444,5555,99,"bcdef"
22,444,5555,99,"bcdef"
Run Code Online (Sandbox Code Playgroud)
然后,您可以使用简单的 awk 命令来操作它(例如)。您可以在字段中包含以“=”开头的公式。例如,
5,99,"=(B5*(B1/A1))"
Run Code Online (Sandbox Code Playgroud)
然后,您可以在 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; }
'
Run Code Online (Sandbox Code Playgroud)
您可以使用以下命令将 new.csv 转换为 .ods:
libreoffice --convert-to ods new.csv
Run Code Online (Sandbox Code Playgroud)
如果您的数据包含“,”和(“),您需要更改各处使用的分隔符。
(要将带有公式的单元格保存为 csv,请执行以下操作:另存为、文件类型文本 CSV、勾选编辑过滤器设置、保存、字段选项:勾选保存单元格公式、勾选引用所有文本单元格。)
我查看了您的示例 data.csv 文件,并在讨论中将其复制到 example.csv。我删除了第 1 行“A、B、C、D、E”(列标题),因为这使得解释文件中的行号与表中的行的对应关系变得更加困难。我用这个 sed 命令做到了这一点:
sed -i '1{/A,B,C/d}' example.csv
Run Code Online (Sandbox Code Playgroud)
如果需要,您可以在最后恢复标头:
sed -i '1i\A,B,C' new.csv
Run Code Online (Sandbox Code Playgroud)
如果您想在 libreoffice 之外实际执行公式算术,您可以在 awk 中执行此操作,如下所示。awk 一次读取一行数据并执行 {} 中的每个命令。$1 设置为第 1 列,依此类推(如 -F,表示列之间用“,”分隔)。我们可以将这些值保存在按行号索引的数组中,例如 A[NR]=$1 将行NR(当前行)的第 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] }
'
Run Code Online (Sandbox Code Playgroud)