遇到问题:
现在有两个脚本,我想
将file1中的内容按file2来匹配
[root@154 home]# cat file1
3-1-1 POTV=1,POTA=0,POTP=2
1-4-76 POTV=1,POTA=0,POTP=1
2-1-2 POTV=1,POTA=1,POTP=1
3-1-4 POTV=1,POTA=1,POTP=2
4-1-5 POTV=1,POTA=1,POTP=2
7-1-2 POTV=1,POTA=1,POTP=2
3-1-10 POTV=1,POTA=1,POTP=2
1-1-1 POTV=1,POTA=2,POTP=0

 

[root@154 home]# cat file2
1-1-1
2-1-2
2-1-3
3-1-4
4-1-5

  

相当于grep的精确匹配,不过是用awk实现的
grep -w '1-1-1' file1
实现用for in循环取值,赋予变量
 
写了一个替换思路用for in循环将匹配内容变为变量,然后匹配替换
for i in `cat file2`
do
awk  '$1==''"'$i'"''{print $0}' file1 >> urfile
done
 
awk  '$1=='   '"'   $i   '"'    '{print $0}'   file1
这段中单引号是脱义的作用
在awk中精确匹配字符,需要将字符用双引号引用:

awk '$1=="1-1-1"{print $0}' test
所以对传递参数要用单引号将双引号脱义让awk识别
单引号成对出现是按就近原则来的

  

这里需要注意的是,这里引用的'$1=='   '"'   $i   '"'    '{print $0}'里面不能有空格,不然会发生语法错误

(猜想大概是因为IFS分段原因,awk被分成了几段话,造成语法错误)

[root@154 home]# cat aemployee.txt
101 John Doe,CEO
102 Jason Smith,IT Manager
103 Raj Reddy,Sysadmin
104 Anand Ram,Developer
105 Jane Miller,Sales Manager
[root@154 home]# awk '$1==''"'101'"''{print $0}' aemployee.txt
101 John Doe,CEO
[root@154 home]# awk '$1==' '"'101'"''{print $0}' aemployee.txt
awk: cmd. line:1: $1==
awk: cmd. line:1: ^ unexpected newline or end of string

  这里就能看出来,应该跟我猜的一样,如果有不对,请大神指点

2017/07/01更新:

之前的方法太蠢了,改进下,因为之前实验失败,所以认为这样是不行的,不过发现好像是之前实验错误:
awk '$1=="'$i'"{print $0}' file1 >> urfile

===================================================================

新需求

其中file1只有270行,
             file2有345行,
             file1的第一列内容都包含在file2中
             这是两个文件的关系
要求:
      我想以file2为样本,将file1第一列匹配file2行进行替换

即file2的第一行为
1-1-1
在file1中存在
1-1-1 POTV=1,POTA=2,POTP=0
然后将file2中内容替换为file1中该行内容(或者添加file1中第二列内容)
即变成以下样子
1-1-1 POTV=1,POTA=2,POTP=0
1-1-2
1-1-3
1-1-4
1-1-5

-------------------------------------------------------------------------

自己编了一个脚本,毕竟没有基础,大神莫笑

脚本1

#!/bin/bash

for i in `cat yrsd`
do
s=`awk '$1==''"'$i'"''{print $0}' test`
if [ "$s" == "" ];
then echo "$i" >>1
else
echo "$s" >>1
fi
done

 脚本2

	#!/bin/bash

	for i in `cat yrsd`
do
echo $i
if [ -z "$(awk '$1==''"'$i'"''{print $0}' test)" ];
then echo "$i" >>1
else
echo "$(awk '$1==''"'$i'"''{print $0}' test)" >>1
fi
done

  

 
既然已经实现了awk替换,那加个判断就能搞定
另外,大神给的方法
 
awk 'FNR==NR{a[$1]=$2;next}{$2=a[$1];print}' file1 file2

  解释一下这个吧,这是使用了awk的内置变量NF和FNR,利用这两个变量,结合数组,先将需要替换的内容组合放到数组里,供匹配使用;

  再使用了next这个内置函数模块,这样的话就可以达到先将内容放到数组里,然后执行匹配替换。

  这里还有一个精彩的地方,在file2文件里,并没有$2这栏,而在执行的时候使用了不存在的$2;

  开始我也疑惑,后来想到,这是一个类似于赋值的方法,原本不存在$2被赋值为替换的内容;

  打印该列,print后不接参数等同于print $0

 
使用awk的FNR与NR的区别,利用数组,一条命令搞定
这里的知识点还是挺多的,看我这篇分析吧,讲的更详细

awk中引用shell变量执行替换的脚本的更多相关文章

  1. awk中引用shell变量的方法

    1.通过命令行参数定义变量时引用: awk -v awk变量名= shell变量名 #!/bin/bash var4bash=test awk -v var4awk="$var4bash&q ...

  2. awk内引用shell变量【自己手动加精】

    题目 [root@localhost ~]# cat 1.txt iii sss ddd 执行命令 [root@localhost ~]# A=0 [root@localhost ~]# awk '{ ...

  3. awk中使用shell变量

    方法:使用-v参数. 对于多个shell变量使用多个-v 有个关于shell变量中的空格问题:

  4. 正则表达式中引用shell变量

    注意,是用单引号包含双引号来引用变量 > MAPPING_ID_PO="000001:AP1-TU1000002:AP1-TU2000003:AP1-TU3000004:AP1-TU4 ...

  5. awk中使用shell的环境变量

    awk中使用shell的环境变量一:"'$var'"这种写法大家无需改变用'括起awk程序的习惯,是老外常用的写法.如:var="test"awk 'BEGIN ...

  6. shell变量的替换,命令的替换,转义字符

    1,shell变量的替换 变量可以根据变量是否为空或者被删除,而被替换为特定的值 ${var}  变量本来的值 $(var:-word)   如果变量为空,或者已被删除那么返回word,但是不改变va ...

  7. Awk中调用shell命令

    Awk中调用shell命令 需求 在awk中,有时候需要调用linux系统中命令,如计算字符串的MD5值,并保存下来. 方法参考 call a shell command from inside aw ...

  8. [转帖]Linux教程(20)- Linux中的Shell变量

    Linux教程(20)- Linux中的Shell变量 2018-08-24 11:30:16 钱婷婷 阅读数 37更多 分类专栏: Linux教程与操作 Linux教程与使用   版权声明:本文为博 ...

  9. awk中可以使用system来执行复杂的shell命令

    在awk中可以直接执行shell命令. zoer@ubuntu:~$ touch a zoer@ubuntu:~$ touch b zoer@ubuntu:~$ cat a.txt a b zoer@ ...

随机推荐

  1. ComboBox 中 DisplayMember 和 ValueMember 都是具体干什么的?

    ComboBox组件的数据绑定,在得到数据集后,只有设定好ComboBox组件的的三个属性就可以完成数据绑定了,这三个属性是:"DisplayMember". "Valu ...

  2. 【转】qlv文件如何转换成mp4 怎样把下载好的qlv格式视频转换成MP4格式

    狸窝  复制  收藏  保存到桌面  快速找教程方案  反馈需求  社会主义核心价值观  客服QQ41442901   马上注册 升级VIP   对于视频文件之间的转换问题,我也已经是无力吐槽了,每个 ...

  3. 一个通用的makefile(一)

    最近在编写Android编译系统时,需要遍历每一个目录下每一个文件夹下的makefile,网上的方法有些繁琐 :就直接贴上自己遍历子目录深度为1:(for  temporary)(之后会继续更新) 下 ...

  4. deeplearning.ai 神经网络和深度学习 week2 神经网络基础 听课笔记

    1. Logistic回归是用于二分分类的算法. 对于m个样本的训练集,我们可能会习惯于使用for循环一个个处理,但在机器学习中,是把每一个样本写成一个列向量x,然后把m个列向量拼成一个矩阵X.这个矩 ...

  5. PL/SQL游标详解

    刚打开游标的时候,是位于一个空行,要用fetch into 才能到第一行. 只是要注意用更新游标的时候,不能在游标期间commit. 否则会报ORA-01002: fetch out of seque ...

  6. js判断是否为ie浏览器

    之前在开发时遇到浏览器的兼容性问题,涉及到对ie浏览器的判断.现在此做个笔记. 这里我以函数的形式来判断,在用的时候直接调用即可. var isIE = !!window.ActiveXObject ...

  7. Maven中央仓库源地址改为阿里云(IDEA)

    我的Maven是IDEA2017.1.2集成的,所以settings.xml在此位置 E:\Program Files\JetBrains\IntelliJ IDEA 2017.1.2\plugins ...

  8. phpstudy php5.4以上版本伪静态设置 thinkphp

    http://www.thinkphp.cn/topic/35958.html <IfModule mod_rewrite.c> Options +FollowSymlinks -Mult ...

  9. PHP开发api接口安全验证

    php的api接口 在实际工作中,使用PHP写api接口是经常做的,PHP写好接口后,前台就可以通过链接获取接口提供的数据,而返回的数据一般分为两种情况,xml和json,在这个过程中,服务器并不知道 ...

  10. DedeCMS首页调用缩略图为背景

    配合{dede:arclist}{/dede:arclist}标签使用,既可以实现把缩略图作为背景,另外还需要用到background-position这个标签,做好背景的定位. http://www ...