首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >批处理文件中的CSV格式

批处理文件中的CSV格式
EN

Stack Overflow用户
提问于 2010-08-25 13:02:47
回答 5查看 701关注 0票数 1

我有一个CSV文件,其中包含许多行,如:

"wmiprvse.exe“、"3596”、“控制台”、"0“、"5,632 K”、“运行”、"NT权限\网络服务“、"0:00:00”、"N/A“

并希望将这些行更改为:

wmiprvse.exe,NT授权\网络服务,N/A

,什么是最好的方法?

到目前为止,我已经使用了以下内容(使用sed):

代码语言:javascript
复制
cat myfile | sed -e "1,2d;s/\"*//g;s/,.*,.*,.*,.*,.*,\(.*\),.*,\(.*\)/,\1,\2/"

但它不能正常工作,有什么建议吗?

EN

回答 5

Stack Overflow用户

回答已采纳

发布于 2010-08-25 13:09:43

你能用awk吗?

正如wilhelmtell和Colin所指出的,用逗号替换每个空格并不是正确的方法,因为它也替换了字符串中的空格,比如NT AUTHORITY\NETWORK SERVICE

用这个代替

代码语言:javascript
复制
$ cat temp | awk 'BEGIN{FS = ","}{print $1","$8","$10}' | sed 's/"//g'
wmiprvse.exe,NT AUTHORITY\NETWORK SERVICE,N/A

旧答案

代码语言:javascript
复制
$ cat temp | awk 'BEGIN{FS = ","}{print $1, $8, $10}' | sed 's/"//g'|
  sed 's/ /,/g'

wmiprvse.exe,NT,AUTHORITY\NETWORK,SERVICE,N/A

1.

代码语言:javascript
复制
awk 'BEGIN{FS = ","}{print $1, $8, $10}'

打印栏1、8和10

2.

代码语言:javascript
复制
sed 's/"//g'

删除"

3.

代码语言:javascript
复制
sed 's/ /,/g'

,替换空间

票数 3
EN

Stack Overflow用户

发布于 2010-08-25 13:09:48

如果您可以在值中使用(转义)引号或逗号,那么正则表达式就不是工作的合适工具。为此您将需要一个指定的状态机。最好的选择是使用Ruby、Python、Perl或类似工具编写一个小脚本。

票数 1
EN

Stack Overflow用户

发布于 2010-08-25 13:10:38

我认为您想要使用awk来实现这个目的:

代码语言:javascript
复制
[jkramer/sgi5k:~]# cat foo
"wmiprvse.exe","3596","Console","0","5,632 K","Running","NT AUTHORITY\NETWORK SERVICE","0:00:00","N/A"
[jkramer/sgi5k:~]# awk -F'","|"' '{print $2 "," $8 "," $10}' foo
wmiprvse.exe,NT AUTHORITY\NETWORK SERVICE,N/A
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/3566073

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档