sed 命令的语法
Syntax of sed command
我在服务器 "dailyconfig.yml" 上有一个文件,其中包含如下行
logFiles: ["responseActions.csv.2015-04-24","responseActions.csv.2015-04-25","responseActions.csv.2015-04-26"]
我必须使用 sed 命令更改每个文件的日期。
我的脚本如下
echo -n "Enter first date (format: YYYY-mm-dd): "
read startDate
echo "startDate outside loop: $startDate"
echo -n "Enter last date (format: YYYY-mm-dd): "
read endDate
echo "endDate outside loop: $endDate"
d1=$(date -d "$endDate" +%s)
echo "d1 = $d1"
d2=$(date -d "$startDate" +%s)
echo "d2 = $d2"
datediff=$(($(((d1-d2)/86400))+1))
echo "datediff = $datediff"
count=1
echo "count outside loop: $count"
while test $count -le $datediff
do
echo "count=$count"
echo "datediff=$datediff"
echo "Entered in loop"
date1=`date +%Y-%m-%d -d "$startDate -1 day"`
echo "date1 = $date1"
date2=`date +%Y-%m-%d -d "$startDate +1 day"`
echo "date2 = $date2"
sed -i "s/startDate:.*18:30:00/startDate: $date1 18:30:00/g" configdaily.yml
sed -i "s/endDate:.*18:30:00/endDate: $startDate 18:30:00/g" configdaily.yml
**sed -i "s/logFiles:*]/logFiles: [\"responseActions.csv.$date1\",\"responseActions.csv.$startDate\",\"responseActions.csv.$date2\"]/g" configdaily.yml**
sleep 10
startDate=$(date +%Y-%m-%d -d "$startDate +1 day")
echo " startDate inside loop: $startDate"
count=$((count+1))
echo "count inside loop: $count"
done
在上面的脚本中,您可以看到三个 sed 命令,其中第三个 sed 命令没有提供所需的输出。
因此,请在第三个 sed 命令中建议正确的语法或更改。
您似乎在使用 logfiles:*
,而您可能指的是 logfiles:.*
。表达式 :*
表示零次或多次重复冒号字符。表达式 .*
表示任何字符的零次或多次重复(另请注意 .
是如何匹配除换行符之外的任何单个字符的元字符)。
切线地,在同一文件上 运行 三个连续的 sed
脚本有点浪费。您应该能够将它们组合成一个脚本:
sed -i -e "s/startDate:.*18:30:00/startDate: $date1 18:30:00/" \
-e "s/endDate:.*18:30:00/endDate: $startDate 18:30:00/" \
-e "s/logFiles:.*]/logFiles: [\"responseActions.csv.$date1\",\"responseActions.csv.$startDate\",\"responseActions.csv.$date2\"]/" configdaily.yml
我还删除了所有这些的 /g
标志,因为您的任何模式似乎都不可能在同一行上匹配多次。 g
的意思是当有多个匹配时,在同一行重复匹配。
sed -i "
s#startDate:.*18:30:00#startDate: ${date1} 18:30:00#g
s#endDate:.*18:30:00#endDate: $startDate 18:30:00#g
s#logFiles:*]#logFiles: [\"responseActions.csv.${date1}\",\"responseActions.csv.${startDate}\",\"responseActions.csv.${date2}\"]#g" configdaily.yml
- action 可以用新行或
;
或最终在多个 -e "Action"
中分隔
- 我使用其他分隔符而不是
/
因为日期和文件名可以使用它但是如果变量内容或模式中没有 /
则它不是强制性的
g
是可选的,因为它每行只处理 1 次出现
我在服务器 "dailyconfig.yml" 上有一个文件,其中包含如下行
logFiles: ["responseActions.csv.2015-04-24","responseActions.csv.2015-04-25","responseActions.csv.2015-04-26"]
我必须使用 sed 命令更改每个文件的日期。
我的脚本如下
echo -n "Enter first date (format: YYYY-mm-dd): "
read startDate
echo "startDate outside loop: $startDate"
echo -n "Enter last date (format: YYYY-mm-dd): "
read endDate
echo "endDate outside loop: $endDate"
d1=$(date -d "$endDate" +%s)
echo "d1 = $d1"
d2=$(date -d "$startDate" +%s)
echo "d2 = $d2"
datediff=$(($(((d1-d2)/86400))+1))
echo "datediff = $datediff"
count=1
echo "count outside loop: $count"
while test $count -le $datediff
do
echo "count=$count"
echo "datediff=$datediff"
echo "Entered in loop"
date1=`date +%Y-%m-%d -d "$startDate -1 day"`
echo "date1 = $date1"
date2=`date +%Y-%m-%d -d "$startDate +1 day"`
echo "date2 = $date2"
sed -i "s/startDate:.*18:30:00/startDate: $date1 18:30:00/g" configdaily.yml
sed -i "s/endDate:.*18:30:00/endDate: $startDate 18:30:00/g" configdaily.yml
**sed -i "s/logFiles:*]/logFiles: [\"responseActions.csv.$date1\",\"responseActions.csv.$startDate\",\"responseActions.csv.$date2\"]/g" configdaily.yml**
sleep 10
startDate=$(date +%Y-%m-%d -d "$startDate +1 day")
echo " startDate inside loop: $startDate"
count=$((count+1))
echo "count inside loop: $count"
done
在上面的脚本中,您可以看到三个 sed 命令,其中第三个 sed 命令没有提供所需的输出。
因此,请在第三个 sed 命令中建议正确的语法或更改。
您似乎在使用 logfiles:*
,而您可能指的是 logfiles:.*
。表达式 :*
表示零次或多次重复冒号字符。表达式 .*
表示任何字符的零次或多次重复(另请注意 .
是如何匹配除换行符之外的任何单个字符的元字符)。
切线地,在同一文件上 运行 三个连续的 sed
脚本有点浪费。您应该能够将它们组合成一个脚本:
sed -i -e "s/startDate:.*18:30:00/startDate: $date1 18:30:00/" \
-e "s/endDate:.*18:30:00/endDate: $startDate 18:30:00/" \
-e "s/logFiles:.*]/logFiles: [\"responseActions.csv.$date1\",\"responseActions.csv.$startDate\",\"responseActions.csv.$date2\"]/" configdaily.yml
我还删除了所有这些的 /g
标志,因为您的任何模式似乎都不可能在同一行上匹配多次。 g
的意思是当有多个匹配时,在同一行重复匹配。
sed -i "
s#startDate:.*18:30:00#startDate: ${date1} 18:30:00#g
s#endDate:.*18:30:00#endDate: $startDate 18:30:00#g
s#logFiles:*]#logFiles: [\"responseActions.csv.${date1}\",\"responseActions.csv.${startDate}\",\"responseActions.csv.${date2}\"]#g" configdaily.yml
- action 可以用新行或
;
或最终在多个-e "Action"
中分隔
- 我使用其他分隔符而不是
/
因为日期和文件名可以使用它但是如果变量内容或模式中没有/
则它不是强制性的 g
是可选的,因为它每行只处理 1 次出现