文件
TxA1000| Tx5000| TxAc2000
Ms67Ty| AtX0000| Tx5000
所需输出:
.Tx5000.
..Tx5000
尝试过的解决方案:
awk -F '|' '!/Tx5000/{next}{gsub(/[aA0-zZ9]/, ".")}1 file
获得的输出:
.......| ......| ........
......| .......| ......
请需要帮助。
答案1
也许:
awk -F '[|] ' -v OFS="" -v ok="Tx5000" '
{for (i=1; i<=NF; i++) if ($i != ok) $i="."; print}
' <<END
TxA1000| Tx5000| TxAc2000
Ms67Ty| AtX0000| Tx5000
END
.Tx5000.
..Tx5000
您的字段分隔符似乎是“管道+空格”,因此参数-F
更具体。
您必须更具体地说明“不适用于文件”的声明:
$ cat >|file
TxA1000| Tx5000| TxAc2000
Ms67Ty| AtX0000| Tx5000
$ awk -F '[|] ' -v OFS="" -v ok="Tx5000" '
{for (i=1; i<=NF; i++) if ($i != ok) $i="."; print}
' file
.Tx5000.
..Tx5000
awk '...' < file
与和 的结果相同cat file | awk '...'
答案2
Python
#!/usr/bin/python
import re
l=re.compile(r'Tx5000')
k=open('rr.txt','r')
for i in k:
if re.search(l,i):
o=i.strip().split("|")
for w in range(0,len(o),1):
we=[]
if (o[w].strip() == "Tx5000"):
for q in range(0,len(o),1):
if (q == w):
we.append("Tx5000")
else:
we.append(".")
print "".join(we).strip()
输出
.Tx5000.
..Tx5000