使用终端命令对 libreoffice calc(电子表格)进行数据操作

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 文件

meu*_*euh 5

最简单的方法是以标准化 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)