sh脚本导出表csv添加列名

sh脚本导出表csv添加列名,第1张

在 Linux 系统中,可以使用 Shell 脚本语言(sh)方便地进行各种 *** 作。如果要导出表格数据到 CSV 文件中,并添加列名,可以使用 Shell 命令 sed。

首先,假设你已经将表格数据保存为名为 data.txt 的文本文件。该文件中的数据是以制表符分隔的,没有列名。

然后,使用以下命令可以在第一行添加列名,并将结果保存为新的 CSV 文件:

```

{ echo "col1,col2,col3"cat data.txt} | sed '蔽睁纤s/\t/,/宏仿g' >data.csv

```

这个命令的含义是:先在 echo 命令中定义列名,使用管道 *** 作将列名和数据一起传递给 sed 命令,然后将制表符替换成早竖逗号,最后将结果保存为 data.csv 文件。

通过这种方式,你可以快速方便地导出 CSV 文件,并添加列名,方便后续处理。

首先我这边先建一个字母大小转换的脚本test2.sh,内容如下:

先介绍些sed -n的应用:

sed命令中p能实现打印匹配行的功能。我们可以实际看下sed命令带-n和不带-n情况下有什么不同。

sed -n "1p" test2.sh:带-n选项的话,只打印test2.sh脚本第一行匹配行。

sed "1p" test2.sh:不带-n的话,不仅打印第一行匹配行,还打印输出test2.sh脚本的全部内容。

sed -n还可以打印文件的范围,比如打印test2.sh脚本的前两行,我们就可以执行以下命令:sed -n "1,2p" test2.sh,就可以直接打印前两行。

sed命令可以打印匹配模式行,比如打印test2.sh脚本匹配tr的行,就可以执行以下命令:

sed -n /tr/p test2.sh。

remark:如果不带-n的话,除了打印匹配行外,还会打印脚本的全部内容。

sed -e的应用。只有当sed命令传递多个编辑命令式,才会使用到-e。比如:我想打印/tr/匹配行,并且打印匹配行所在的行号,此时存在多个sed参数,就要用到-e了。

sed -n -e /tr/p -e /tr/= test2.sh

每个参数前都要带上-e:

sed a\追加命令,命令格式为:sed ’指定地址a\追加内容‘ 目标文件

这个追加内容在匹配行的下一行,只会输出到标准输出,原文件内容是不变的,例如在test2.sh脚本的/tr/所在的匹配行的下一行添加“#hello”内容,可需要执行:

sed '/tr/a\#hello' test2.sh

一定不要忘记单引号.

还有一个sed i\的追加命令,命令格式为:sed ’卜态指定地址i\追加内容‘ 目标文件,跟a\不同,i\追加是在指定位置的上一行追加命令

sed命令中还有一些特殊的匹配,比如元字符匹配,此时需要用转义符"\"屏蔽其特殊意义。

比如:sed -n ‘/\=/p’test2.sh,则打印输出tr一行。

$在正则表达式中表示尾行,执行sed -n ‘$p’ test2.sh则打印脚本尾行。

!表示取反,可以看以下两个例子

sed中可以使用关键字来匹配行,打印我们所需要的内容,比如,我希望打印test2.sh第2,3行,可以执行:sed -n "2,3P" test2.sh,也可以执行sed -n "/tr/,/exit/p" test2.sh

sed c\的应用,命令格式为:sed ’指定地址c\替换内容‘ 目标文件。比如,#hello,替换test2.sh脚本的tr这行,可以执行命令:sed '/tr/c\#hello' test2.sh

sed删除d应用:比如我想删除test2.sh的第2行,可以执行以下命令:sed "2d" test2.sh或者sed /tr/d test2.sh

sed替换s应用:格式 sed s/被替换的字符/替换字符/[替换选项]

比如,我想把test2.sh中tr替换成大写的tr,则可以执行以下命令:sed ‘s/tr/TR/’test2.sh,则把脚本中的tr替换成TR,完后输出全部内容。

如果仅想打印替换所在行,则需要试用使用-n和-p:sed -n ‘s/tr/TR/p’ test2.sh:把脚本中的tr替换成TR,然后打印tr所在的行.

如果脚本中存在好几个tr,并且每一行也存在多个tr,如果执行以上命令的话,只会型乱源更改每一行的第一个出现的tr,如陪敬果要全部把tr转后为TR,则需要添加G参数:

sed -n ’S/tr/TR/pg’test2.sh。

w参数是定向输入参数,比如要把上述的变更定向输出到test1.txt中,则需要执行:

sed -n ’s/tr/TR/pgw test1.txt’ test2.sh。

也可以直接把选定的匹配内容写到另一个文本中,比如想把test2.sh中tr这一样写到test2.txt中,执行:sed -n ’/tr/w test2.txt‘ test2.sh

添加一穗御个文件的内容,也不进行改变,建议直接cat两个文件,重定向到一个新文件,再对新知咐文件进行处理

cat text1 text2 >tmp.txt

如果非要这个新文件的名称还是text2,可以mv

如果搭族纯只是在文件开头加一行内容,可以用:

sed '1i 要添加的一行文本' 要处理的文件名


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/bake/11986273.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-20
下一篇 2023-05-20

发表评论

登录后才能评论

评论列表(0条)

保存