我有以下内容:
...
#define DIRT 4
#define PLANKS 5
#define WOOD_PLANKSs 5
#define BRICKS 6
...
我需要删除与它们之前的行具有相同编号的行之一(例如,删除木板,因为木板具有相同的编号,5)。
是否有一种方法可以在 linux(或 Windows)脚本中执行此操作,可能使用 if then 语句?
我有以下内容:
...
#define DIRT 4
#define PLANKS 5
#define WOOD_PLANKSs 5
#define BRICKS 6
...
我需要删除与它们之前的行具有相同编号的行之一(例如,删除木板,因为木板具有相同的编号,5)。
是否有一种方法可以在 linux(或 Windows)脚本中执行此操作,可能使用 if then 语句?
在 Linux 中,使用uniq
命令和-f
参数跳过比较前两个字段:uniq -f 2 <your-file>
创建一个名为 removeDup.awk 的 awk 脚本
1 BEGIN { lastDefine=""
2 }
3 /^#define/ { if (lastDefine=="") {
4 lastDefine=$3
5 } else {
6 if (lastDefine==$3) {
7 next
8 } else {
9 lastDefine=$3
10 }
11 }
12 }
13 { print
14 }
awk -f removeDup.awk 文件名