你的正则表达式 ^((?!bbb).)/d 几乎正确,但缺少一个关键点。这个表达式使用了负向前瞻断言 (?!bbb) 来匹配不包含 bbb 子字符串的行。但是它还需要一个具体的匹配字符或字符集,以便用于匹配行的所有其他内容。
你可以尝试将表达式修改为 ^[^b]*(?!bbb).*$,它将匹配行首的任何数量的非 b 字符,然后检查该行是否包含 bbb,然后最终匹配行末的所有字符。这样,对于所有不包含 bbb 的行,该表达式将与行完全匹配,从而允许 sed 工具将其删除。
因此,你可以使用以下命令来删除文件中不包含子字符串 bbb 的所有行:
Copy code
sed -i '/^[^b]*\(bbb\)\?$/d' filename
如果要在脚本文件中使用,则可以将其存储在 delete_lines.sh 中:
Copy code
#!/bin/bash
sed -i '/^[^b]*\(bbb\)\?$/d' "$1"
然后,在终端中运行以下命令:
Copy code
chmod +x delete_lines.sh
./delete_lines.sh filename
这将执行 delete_lines.sh 脚本并删除文件 filename 中不包含子字符串 bbb 的所有行。
grep bbb file > file1
cat file1 > file
whudwl 的更好
sed - '/bbb/!d' filename
这样就可以了吧.