linux - 如果等于或小于,则需要带 awk 的 hep
问题描述
与我之前发布的帖子类似,我正在尝试以下操作:
Myfile.txt 包含:
$TTL 600
@ IN SOA dns1.mysite.com. root.localhost. (
2020042101 ; serial
1h ; refresh
30m ; retry
1w ; expiry
30m) ; minimum
IN NS localhost.
dns1.mysite.com IN A 172.16.1.18
dns2.mysite.com IN A 172.16.2.18
; Redirect this site to localhost to block
; List last consolidated on 12/11/2018
; DNS Blocks
*.mad IN CNAME *.
beans.com A 127.0.0.1 ; this is a test case
*.000webhostapp.com A 127.0.0.1
*.00h5.com A 127.0.0.1
*.00webhostapp.com A 127.0.0.1
myscript.sh 包含:
date=$ (date '+%y%m%d'01)
ydate=$ (date -d yesterday '+%y%m%d'01)
awk "{sub(/$ydate/,$date)}1" myfile.txt > tempt.txt && mv temp.txt myfile.txt
就目前而言,如果文件中的日期仅与昨天的日期匹配,则此方法有效。我现在要做的是匹配昨天或之前的日期,如果是,则将其替换为 $date,然后覆盖文件。
我知道 awk 可以用“n1 -le n2”来做到这一点,但我不能让它与我正在使用的操作内联工作。
任何人都可以帮助我让它工作吗?
谢谢!
解决方案
使用<=
比较。然后,您可以使用替换重新分配该字段。
awk -v yesterday="$date" -v today="$ydate" '/; serial/ && $1 <= yesterday { sub(/[0-9]+/, today) }1' myfile.txt > temp.txt
并且通常更好地分配awk
变量-v
而不是将shell变量替换到脚本中。