awk not in命令

时间: 2023-10-12 18:04:47 浏览: 62
在 awk 中,没有内置的 `not in` 命令,但你可以使用逻辑运算符和条件语句来实现类似的功能。 假设你有两个文件 `file1.txt` 和 `file2.txt`,你想要在 `file1.txt` 中找到不在 `file2.txt` 中出现的行。你可以使用以下方法: ```bash awk 'NR==FNR { data[$0]=1; next } !($0 in data)' file2.txt file1.txt ``` 这个命令的解释如下: - `NR==FNR { data[$0]=1; next }`:当处理第一个文件 `file2.txt` 时,将每一行的内容作为键存储在 `data` 数组中。`NR` 表示当前行号,`FNR` 表示当前文件的行号,只有在处理第一个文件时,这个条件才会成立。 - `!($0 in data)`:当处理第二个文件 `file1.txt` 时,对于每一行,检查该行是否不在 `data` 数组中,如果是,则打印该行。 运行以上命令后,将输出在 `file1.txt` 中不在 `file2.txt` 中出现的行。 请注意,上述命令假设每行的内容是唯一的。如果有重复行,请根据实际情况进行调整。另外,如果你想要更精确的匹配,请使用适当的字段分隔符和比较字段。
相关问题

#!/bin/bash sum=0 #注意第一行为%MEM字符串 while read line in $(awk '{print $4}' nowcoder.txt) do [ $line != "%MEM" ] && sum=$(echo "$line+$sum" | bc) done echo $sum exit 0 line 4: read: `%MEM': not a valid identifier

这个错误是因为在while read line语句中,read会将输入行分解为单词,并将其分配给变量line。而在这个例子中,awk输出的第一行是字符串"%MEM",它包含了一个非法变量名字符"%", 因此read无法将其分配给变量line,从而报错。 为了避免这个问题,你可以在while循环中添加一个过滤条件来跳过第一行,比如这样: ```bash #!/bin/bash sum=0 while read line do if [[ $line != "%MEM"* ]]; then mem=$(echo $line | awk '{print $4}') sum=$(echo "$mem+$sum" | bc) fi done < nowcoder.txt echo $sum exit 0 ``` 这个脚本中,我们使用if语句来判断读入的行是否以"%MEM"开头。如果不是,则使用awk提取第四个字段(即内存占用百分比),并将其加入sum中。注意,我们将文件名作为输入重定向到while循环中,这样就可以避免第一行被read命令误解为变量名了。

XENOMAI_DEV="$(apt-cache search -n libxenomai-dev | head -1 | awk '{print $1}')" if [ ! -z "$XENOMAI_DEV" ]; then if [ `apt-cache showsrc libxenomai-dev 2>/dev/null | wc -l` -eq 0 ]; then cat 1>&2 <<-EOF Package libxenomai-dev exists, but information about its source package is not available. This most likely means that you do not have the right deb-src lines in /etc/apt, or that you need to "apt-get update". EOF exit 99 fi XENOMAI_ARCHITECTURE="$(apt-cache showsrc libxenomai-dev \ | grep ^Architecture: \ | head -1 \ | tr '[:space:]' '\n' \ | tail -n +2 \ | grep -vw all \ | tr '\n' ' ')" XENOMAI_DEV="$(apt-cache showsrc libxenomai-dev \ | grep ^Architecture: \ | head -1 \ | tr '[:space:]' '\n' \ | tail -n +2 \ | grep -vw all \ | sed "s/.*/$XENOMAI_DEV [&],/" \ | tr '\n' ' ')" fi

这段代码是在Linux系统中进行特化配置的脚本中的一部分。它的作用是检查系统中是否安装了名为"libxenomai-dev"的软件包,并根据检查结果来设置"XENOMAI_DEV"和"XENOMAI_ARCHITECTURE"变量。具体来说,这段代码使用了"apt-cache search"命令来查找系统中安装的"libxenomai-dev"软件包,并使用"head -1"命令来获取搜索结果的第一行,然后使用"awk"命令提取出第一列,即软件包的名称。 接着,这段代码检查"XENOMAI_DEV"是否为空,如果不为空,则继续执行下面的代码。该代码使用"apt-cache showsrc"命令来获取"libxenomai-dev"软件包的源代码包信息。如果获取失败,则输出一条错误信息,并以非零退出码退出脚本。如果获取成功,则使用一系列命令来提取"XENOMAI_ARCHITECTURE"和"XENOMAI_DEV"变量的值。具体来说,这段代码首先使用"grep"命令查找"Architecture"行,并使用"head -1"命令获取第一行,然后使用"tr"命令将空格替换为换行符,使用"tail"命令跳过第一行,使用"grep"命令过滤掉"all"体系结构,最后使用"tr"命令将多行结果合并为一行,并将结果赋值给"XENOMAI_ARCHITECTURE"变量。 接着,这段代码继续使用一系列命令来提取"XENOMAI_DEV"变量的值。具体来说,这段代码使用相同的命令来提取"XENOMAI_ARCHITECTURE"变量的值,然后使用"sed"命令将"XENOMAI_DEV"变量的值替换为"XENOMAI_DEV [&],",其中"[]"表示"XENOMAI_DEV"变量的值,"&"表示源代码包的名称。最后,这段代码使用"tr"命令将多行结果合并为一行,并将结果赋值给"XENOMAI_DEV"变量。

相关推荐

解释脚本:#!/bin/bash #version: 0.1.0 20230510 totalstarttime=$(date +%s) # 计算间隔时间 pkg_name=pwd |sed 's/\// /g'| awk '{print$NF}' SWITCH_FW=${pkg_name::-8}"SIGN.fw" cd pwd G4XDIAG=./g4Xdiagnostics.x86_64 result_log=SR6295A_793_PCIeFW_UPDATE_date '+%Y%m%d%H%M%S'.log mpt_cnt=lsmod | grep -i mpt3sas | wc -l if [ $mpt_cnt != 0 ];then rmmod mpt3sas fi mpt3sas_driver=ls | grep "mpt3sas-" tar -zxvf $mpt3sas_driver cd mpt3sas/ ./compile.sh ./load.sh cd ../ echo -e "\n Switch Firmware Is Upgrading!!! \n" CNT=$G4XDIAG -i 1 list | grep "MPI" | wc -l echo "FW Image Is:" >> $result_log echo $SWITCH_FW | grep "SR6295A_793" >> $result_log if [ $? != 0 ]; then echo "PCIe FW Name Is Not Matched!" >> $result_log echo -e "\n FAIL: PCIe FW Name Is Not Matched! \n" exit 1 else if [ $CNT != 4 ];then echo "Lost switch!" >> $result_log $G4XDIAG -i 1 list >> $result_log echo -e "\n FAIL: Lost switch \n" exit 1 fi fi #Check platform for i in $(seq 1 1 $CNT) do hq_cmd=$G4XDIAG -i $i cli showloc | grep "Current Switch Location" | wc -l if [ $hq_cmd == 0 ];then echo -e "\n Platform Is Not Matched! \n" >> $result_log echo -e "\n FAIL:Platform Is Not Matched!\n" exit 1 fi done #FW upgrade for i in $(seq 1 1 $CNT) do $G4XDIAG -i $i cli showloc >> $result_log $G4XDIAG -i $i dl -f $SWITCH_FW -s >> $result_log ret=cat $result_log | tail -n 5 | grep -i "successfully" | wc -l if [ $ret == 1 ];then echo -e "\n Switch FW Download SUCCESS!!! \n" >> $result_log else echo -e "\n Switch FW Download FAIL!!! \n" >> $result_log echo -e "\n Switch FW Download FAIL!!! \n" exit 1 fi done echo -e "\n Upgrade PASS!!! Need restart the system to make the fresh image active! \n" totalendtime=$(date +%s) echo -e "\n Total FW update finished! Total cost time : $(( $totalendtime - $totalstarttime )) s\n" >> $result_log sleep 5 exit 0

以下shell脚本是什么意思,转成python是什么样的: if [ -s "${UUT_SN[itemloop]}_level3_item.txt" ] ; then format_error_line=() invalid_error_line=() line_count=0 while read itemline do ((line_count++)) if ! grep -iE "^[.+][ ]{1,}pass .+|^[.+][ ]{1,}fail .+" <<<"$itemline" ; then format_error_line[${#format_error_line[@]}]="$line_count" fi #检查三层记录文件里是否有不可识别的符号 line_mark_count=$(awk -F "" '{print NF}' <<<"$itemline") for((line_mark_loop=0;line_mark_loop<line_mark_count;line_mark_loop++)) do line_mark_ascii=$(echo "${itemline:line_mark_loop:1}" | awk 'BEGIN{for(i=0;i<255;i++)a[sprintf("%c",i)]=i}{print a[$0]}') if ! [[ ${line_mark_ascii} -ge 32 && ${line_mark_ascii} -le 126 ]] ; then invalid_error_line[${#invalid_error_line[@]}]="$line_count" continue 2 fi done done <"${UUT_SN[itemloop]}_level3_item.txt" if [ "0" != "${#format_error_line[@]}" ] ; then mv ${UUT_SN[itemloop]}_level3_item.txt ${UUT_SN[itemloop]}_level3_item.old echo "[level3_format] Fail $(date +"%y-%m-%d %H:%M:%S") format error,please check ${UUT_SN[itemloop]}_level3_item.old in line:${format_error_line[@]}" | tee "${UUT_SN[itemloop]}_level3_item.txt" fi if [ "0" != "${#invalid_error_line[@]}" ] ; then [ ! -s ${UUT_SN[itemloop]}_level3_item.old ] && mv ${UUT_SN[itemloop]}_level3_item.txt ${UUT_SN[itemloop]}_level3_item.old echo "[level3_invalid_word] Fail $(date +"%y-%m-%d %H:%M:%S") content invalid word,please check ${UUT_SN[itemloop]}_level3_item.old in line:${invalid_error_line[@]}" | tee "${UUT_SN[itemloop]}_level3_item.txt" fi fi

最新推荐

recommend-type

pre_o_1csdn63m9a1bs0e1rr51niuu33e.a

pre_o_1csdn63m9a1bs0e1rr51niuu33e.a
recommend-type

matlab建立计算力学课程的笔记和文件.zip

matlab建立计算力学课程的笔记和文件.zip
recommend-type

FT-Prog-v3.12.38.643-FTD USB 工作模式设定及eprom读写

FT_Prog_v3.12.38.643--FTD USB 工作模式设定及eprom读写
recommend-type

zigbee-cluster-library-specification

最新的zigbee-cluster-library-specification说明文档。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

实现实时数据湖架构:Kafka与Hive集成

![实现实时数据湖架构:Kafka与Hive集成](https://img-blog.csdnimg.cn/img_convert/10eb2e6972b3b6086286fc64c0b3ee41.jpeg) # 1. 实时数据湖架构概述** 实时数据湖是一种现代数据管理架构,它允许企业以低延迟的方式收集、存储和处理大量数据。与传统数据仓库不同,实时数据湖不依赖于预先定义的模式,而是采用灵活的架构,可以处理各种数据类型和格式。这种架构为企业提供了以下优势: - **实时洞察:**实时数据湖允许企业访问最新的数据,从而做出更明智的决策。 - **数据民主化:**实时数据湖使各种利益相关者都可
recommend-type

2. 通过python绘制y=e-xsin(2πx)图像

可以使用matplotlib库来绘制这个函数的图像。以下是一段示例代码: ```python import numpy as np import matplotlib.pyplot as plt def func(x): return np.exp(-x) * np.sin(2 * np.pi * x) x = np.linspace(0, 5, 500) y = func(x) plt.plot(x, y) plt.xlabel('x') plt.ylabel('y') plt.title('y = e^{-x} sin(2πx)') plt.show() ``` 运行这段
recommend-type

JSBSim Reference Manual

JSBSim参考手册,其中包含JSBSim简介,JSBSim配置文件xml的编写语法,编程手册以及一些应用实例等。其中有部分内容还没有写完,估计有生之年很难看到完整版了,但是内容还是很有参考价值的。
recommend-type

"互动学习:行动中的多样性与论文攻读经历"

多样性她- 事实上SCI NCES你的时间表ECOLEDO C Tora SC和NCESPOUR l’Ingén学习互动,互动学习以行动为中心的强化学习学会互动,互动学习,以行动为中心的强化学习计算机科学博士论文于2021年9月28日在Villeneuve d'Asq公开支持马修·瑟林评审团主席法布里斯·勒菲弗尔阿维尼翁大学教授论文指导奥利维尔·皮耶昆谷歌研究教授:智囊团论文联合主任菲利普·普雷教授,大学。里尔/CRISTAL/因里亚报告员奥利维耶·西格德索邦大学报告员卢多维奇·德诺耶教授,Facebook /索邦大学审查员越南圣迈IMT Atlantic高级讲师邀请弗洛里安·斯特鲁布博士,Deepmind对于那些及时看到自己错误的人...3谢谢你首先,我要感谢我的两位博士生导师Olivier和Philippe。奥利维尔,"站在巨人的肩膀上"这句话对你来说完全有意义了。从科学上讲,你知道在这篇论文的(许多)错误中,你是我可以依
recommend-type

实现实时监控告警系统:Kafka与Grafana整合

![实现实时监控告警系统:Kafka与Grafana整合](https://imgconvert.csdnimg.cn/aHR0cHM6Ly9tbWJpei5xcGljLmNuL21tYml6X2pwZy9BVldpY3ladXVDbEZpY1pLWmw2bUVaWXFUcEdLT1VDdkxRSmQxZXB5R1lxaWNlUjA2c0hFek5Qc3FyRktudFF1VDMxQVl3QTRXV2lhSWFRMEFRc0I1cW1ZOGcvNjQw?x-oss-process=image/format,png) # 1.1 Kafka集群架构 Kafka集群由多个称为代理的服务器组成,这