Bash脚本正则表达式...如何查找和替换所有匹配?

时间:2011-04-14 03:05:40

标签: regex bash shell search replace

我正在编写一个逐行读取文件的bash脚本。

该文件是.csv文件,其中包含DD / MM / YYYY格式的许多日期,但我想将它们更改为YYYY-MM-DD。

我想使用正则表达式匹配数据,并替换它以使文件中的所有日期都正确格式化为YYYY-MM-DD。

我相信这个正则表达式会匹配日期:

([0-9][0-9]?)/([0-9][0-9]?)/([0-9][0-9][0-9][0-9])

但是我不知道如何找到正则表达式匹配并用新格式替换它们,或者甚至可以在bash脚本中使用它。请帮忙!

4 个答案:

答案 0 :(得分:21)

尝试使用sed:

line='Today is 10/12/2010 and yesterday was 9/11/2010'
echo "$line" | sed -r 's#([0-9]{1,2})/([0-9]{1,2})/([0-9]{4})#\3-\2-\1#g'

OUTPUT:
Today is 2010-12-10 and yesterday was 2010-11-9

PS:在Mac上使用sed -E代替sed -r

答案 1 :(得分:16)

Pure Bash。

infile='data.csv'

while read line ; do
  if [[ $line =~ ^(.*),([0-9]{1,2})/([0-9]{1,2})/([0-9]{4}),(.*)$ ]] ; then
    echo "${BASH_REMATCH[1]},${BASH_REMATCH[4]}-${BASH_REMATCH[3]}-${BASH_REMATCH[2]},${BASH_REMATCH[5]}"
  else
    echo "$line"
  fi
done < "$infile"

输入文件

xxxxxxxxx,11/03/2011,yyyyyyyyyyyyy          
xxxxxxxxx,10/04/2011,yyyyyyyyyyyyy          
xxxxxxxxx,10/05/2012,yyyyyyyyyyyyy          
xxxxxxxxx,10/06/2011,yyyyyyyyyyyyy          

给出以下输出:

xxxxxxxxx,2011-03-11,yyyyyyyyyyyyy
xxxxxxxxx,2011-04-10,yyyyyyyyyyyyy
xxxxxxxxx,2012-05-10,yyyyyyyyyyyyy
xxxxxxxxx,2011-06-10,yyyyyyyyyyyyy

答案 2 :(得分:2)

您可以使用sed

执行此操作
echo "11/12/2011" | sed -E 's/([0-9][0-9]?)\/([0-9][0-9]?)\/([0-9][0-9][0-9][0-9])/\3-\2-\1/'

答案 3 :(得分:-1)

我不想回声...我想将结果存储在新变量中

做到这一点(我知道这并不适合您的设置,但仍然适用于如何使用正则表达式):

MFA