我在文件1中有以下内容
'a 62-182'
'a 183-303'
'a 304-424'
...
有什么方法可以根据 file1 的值在文件 2 中获得以下内容吗?
'a 62-182' 'a 7195-7315'
'a 183-303' 'a 7316-7436'
'a 304-424' 'a 7437-7557'
...
那么添加一个额外的列,它+7133文件1中的算术值?
答案1
这awk脚本获取数据的第二个字段并将其拆分为可在数学运算中使用的变量:
$ cat data
'a 62-182'
'a 183-303'
'a 304-424'
$ awk '{ split($2,arr,"-");
print $0"\t"$1, arr[1] + 7133 "-" arr[2] + 7133"\047" }' data
'a 62-182' 'a 7195-7315'
'a 183-303' 'a 7316-7436'
'a 304-424' 'a 7437-7557'
答案2
awk '{gsub("-"," ",$0);print $1,$2"-"$3" "$1,$2+7133"-"$3+7133"'\''"}' filename
输出
'a 62-182' 'a 7195-7315'
'a 183-303' 'a 7316-7436'
'a 304-424' 'a 7437-7557'
Python
#!/usr/bin/python
import re
k=open ('p','r')
for i in k:
d=i.strip().replace('-',' ').replace("'","").split(' ')
print "'"+d[0]+" "+d[1]+"-"+d[2]+"' "+"'"+d[0],str(int(d[1])+7133)+"-"+str(int(d[2])+7133)+"'"