AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / ubuntu / 问题 / 638372
Accepted
Eka
Eka
Asked: 2015-06-20 00:13:31 +0800 CST2015-06-20 00:13:31 +0800 CST 2015-06-20 00:13:31 +0800 CST

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

  • 772

是否可以使用终端命令在 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文件

command-line
  • 1 1 个回答
  • 4173 Views

1 个回答

  • Voted
  1. Best Answer
    meuh
    2015-06-20T06:03:13+08:002015-06-20T06:03:13+08:00

    最简单的方法是以标准 CSV 格式从 libreoffice 中保存文件,通常以“,”作为分隔符并在 (") 中引用文本,并这样保存公式。您的数据应如下所示:

    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 将行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] }
    '
    
    • 5

相关问题

  • 如何从命令行仅安装安全更新?关于如何管理更新的一些提示

  • 如何从命令行刻录双层 dvd iso

  • 如何从命令行判断机器是否需要重新启动?

  • 文件权限如何工作?文件权限用户和组

  • 如何在 Vim 中启用全彩支持?

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    如何运行 .sh 脚本?

    • 16 个回答
  • Marko Smith

    如何安装 .tar.gz(或 .tar.bz2)文件?

    • 14 个回答
  • Marko Smith

    如何列出所有已安装的软件包

    • 24 个回答
  • Marko Smith

    无法锁定管理目录 (/var/lib/dpkg/) 是另一个进程在使用它吗?

    • 25 个回答
  • Martin Hope
    Flimm 如何在没有 sudo 的情况下使用 docker? 2014-06-07 00:17:43 +0800 CST
  • Martin Hope
    Ivan 如何列出所有已安装的软件包 2010-12-17 18:08:49 +0800 CST
  • Martin Hope
    La Ode Adam Saputra 无法锁定管理目录 (/var/lib/dpkg/) 是另一个进程在使用它吗? 2010-11-30 18:12:48 +0800 CST
  • Martin Hope
    David Barry 如何从命令行确定目录(文件夹)的总大小? 2010-08-06 10:20:23 +0800 CST
  • Martin Hope
    jfoucher “以下软件包已被保留:”为什么以及如何解决? 2010-08-01 13:59:22 +0800 CST
  • Martin Hope
    David Ashford 如何删除 PPA? 2010-07-30 01:09:42 +0800 CST

热门标签

10.10 10.04 gnome networking server command-line package-management software-recommendation sound xorg

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve