【问题标题】:Appending two CSV files together via columns [duplicate]通过列将两个CSV文件附加在一起[重复]
【发布时间】:2013-11-25 22:31:30
【问题描述】:

假设我在Ubuntu 的文件夹/home/user 中有两个名为A 和B 的CSV 文件。将B 附加到A 的命令是什么?我更喜欢不复制 A 的命令,但会接受不遵守此偏好的答案。

我已经询问过Python 的情况,但这个问题不是关于Python

A的头是这样的:

  headerNameA1,headerNameA2
  1.12412424,1
  1,1
  1,1
  1,1

B的头长这样:

 headerNameB1,headerNameB2
  1,1
  1,1
  1,1
  1,1

我的目标是获取 B 并将其附加到 A 上,以便 A 看起来像:

  headerNameA1,headerNameA2,headerNameB1,headerNameB2
  1,1,1.12412424,1
  1,1,1,1
  1,1,1,1
  1,1,1,1

【问题讨论】:

  • 您的标题和值与您想要的输出不匹配 - 1.12412424 应该与 headerNameA1 在同一列中
  • 你刚刚问过same question
  • @devnull 另一个问题是针对Python,其解决方案看起来与该问题的解决方案完全不同。请根据此信息撤销您的反对票。
  • 哦,不。你也问过here!你在this comment 中被告知So are you looking for a Python version of paste -d , f1.csv f2.csv
  • @jkshah 那又怎样?如果我用一种语言和另一种语言询问关于空指针异常的相同问题,我认为这些问题应该放在不同的问题中,因为答案涉及 (a) 不同的受众,并且 (b) 可能会完全不同。

标签: bash ubuntu csv io append


【解决方案1】:

paste 成功:

$ paste -d',' a b
headerNameA1,headerNameA2,headerNameB1,headerNameB2
1.12412424,1,1,1
1,1,1,1
1,1,1,1
1,1,1,1

-d',' 部分告诉 paste 使用分隔符 ,(逗号)。

【讨论】:

  • ab 会发生什么? b 是否进入 ab 之后会被删除吗?还是在同一目录中创建了第三个文件?
  • 结果出现在您的屏幕上。如果要将其保存在文件中,则将其重定向:paste -d',' a b > result_file 会将其保存在 result_file 中。
  • 我可以用paste -d',' a b > a 覆盖a 并包含ab 附加在一起的新文件吗?
  • 不,它会截断a,因为您不能同时使用其中一个文件作为重定向的参数。尝试做paste -d',' a b > result_file && mv result_file a。它将输出到result_file,然后将其移动到a,所以a最终会得到结果。
  • 对你有用吗,@user2763361?
猜你喜欢
  • 2013-11-25
  • 1970-01-01
  • 1970-01-01
  • 2020-09-05
  • 1970-01-01
  • 2019-03-28
  • 2014-10-06
  • 2019-11-20
  • 2013-01-17
相关资源
最近更新 更多