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"变量。