linux awk 某一列合并,利用shell中awk和xargs以及sed将多行多列文本中某一列合并成一行...

1、问题描述

最近须要利用Shell将多行多列文本中某一列,经过指定的分隔符合并成一行。假设须要处理的文本以下:

a8905bfdf5440e41a09104d8161684a4.png

咱们主要处理的是,将用户名提取处理,合并成一行,并经过逗号进行分隔。最终的格式以下:html

“li1”,”huan”,”wang”,”wu”,”78c”,”zh”,”liu”,”zhao”,”xu”,”yang”nginx

2、解决方案

首先是提取每一行的第X列,我最早可以想到的是awk命令,以下web

awk '{print $2}' user1.txt

效果以下:

8a7e4e6abb767f4d632968cc2b41c3a4.png

接着,是否是能够把替换符替换为逗号呢?

使用tr命令svg

awk '{print $2}' user1.txt |tr "\n" ","

效果:

df1dd20b941a31735e6cf263dd5e2328.png

看着好像是很接近,咱们将上面的 , 分隔改成”,”分隔,是否是就okey了呢?命令以下:工具

awk '{print $2}' user1.txt |tr "\n" "\",\""

只是很遗憾,执行效果以下:

c3564bc5bd61e4a055b93d48c0cb3258.png

为何呢?spa

由于tr是单个字符处理工具,而不是字符串处理工具。code

既然tr不能够替换字符串,那么我们就用sed命令。由于sed命令不单单能够处理字符,还能够处理字符串。xml

先来个简单的,将换行替换成逗号,命令以下:htm

awk '{print $2}' user1.txt |sed 's/\n/,/g'

执行结果以下:

3facb5e9731853534f8d26a253c4a8dd.png

好吧,居然不听话。为何呢?blog

由于sed命令处理过程是:从文本流中读取一行文本后,先把换行符去掉,而后进行相应的命令,处理完后再添加上换行符。这就致使sed命令,没法对换行符进行直接替换。

既然这样行不通,怎么搞呢?

解决方案一:

既然sed不能修改换行符,那就是在使用sed以前,把换行符干掉。干掉换行符,能够使用tr和xargs命令。

#使用xargs命令干掉换行符

awk '{print $2}' user1.txt |xargs

#使用tr命令干掉换行符

awk '{print $2}' user1.txt |tr "\n" " "

c068c78e4b14caae8837e8402d3f2ef7.png

使用sed命令将空格替换成”,”,命令以下:

awk '{print $2}' user1.txt |xargs |sed 's/ /","/g'

8524ab9e3f5cc99b3c2fa1ecdc058e6f.png

可是开头和结尾少了一个双引号,解决方案以下:

echo '"'`awk '{print $2}' user1.txt |xargs |sed 's/ /","/g'`'"'

解决方案二:

echo '"'`awk '{print $2}' user1.txt | sed ':label;N;s/\n/","/;b label'`'"'

6a183cc02dd74a5e3fc10247232c745c.png

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值