我的文件的输入如下
Koe par 22-10-1992 nep
Ler par 10-04-2000 sis
我希望输出如下
Koe par 1992 nep
Ler par 2000 is
答案1
我不知道,awk
但这sed
有效:
sed -E 's/dates/years/;s/[0-9]{2}-[0-9]{2}-//g' birthdates
id birthyears pref
Koe 1992 nep
Ler 2000 sis
如果保持列整齐对齐很重要,请执行以下操作:
sed -E 's/dates/years/;s/[0-9]{2}-[0-9]{2}-([0-9]{4})/\1 /g' birthdates
id birthyears pref
Koe 1992 nep
Ler 2000 sis
birthdates
这个文件在 哪里:
id birthdates pref
Koe 22-10-1992 nep
Ler 10-04-2000 sis
sed --version
sed (GNU sed) 4.2.2
答案2
和awk
:
awk '{if (NR==1) {print $0} else {split($2,result,"-"); print $1 " " result[3] " " $3}}' birthdates
答案3
以下代码应该有效:
sed 's/birthdates/birthyears/g; s/[0-9]\{1,2\}-[0-9]\{1,2\}-\([0-9]\{4\}\)/\1/g' < myfile.txt > output.txt
例子:
ron@ron:~$ cat myfile.txt
id birthdates pref
Koe 22-10-1992 nep
Ler 10-04-2000 sis
ron@ron:~$ sed 's/birthdates/birthyears/g; s/[0-9]\{1,2\}-[0-9]\{1,2\}-\([0-9]\{4\}\)/\1/g' < myfile.txt > output.txt
ron@ron:~$ cat output.txt
id birthyears pref
Koe 1992 nep
Ler 2000 sis
答案4
sed -r 's/(.+)[ ]+(.+)[ ]+([0-9]{2}-[0-9]{2}-)([0-9]{4})[ ]+(.+)/\1 \2 \4 \5/'