Linux sed-如何精确匹配行中的数字
请给出建议,如何告诉sed精确匹配数字 比如说, 关于file.csv文件,我们只想在以数字1开头的行(在“,”分隔符之前)将单词STATUS更改为OK 但sed也将以12开头的行上的状态替换为OK 那么,如何更改sed语法以精确匹配分隔符前的第一个数字呢Linux sed-如何精确匹配行中的数字,linux,sed,Linux,Sed,请给出建议,如何告诉sed精确匹配数字 比如说, 关于file.csv文件,我们只想在以数字1开头的行(在“,”分隔符之前)将单词STATUS更改为OK 但sed也将以12开头的行上的状态替换为OK 那么,如何更改sed语法以精确匹配分隔符前的第一个数字呢 more file.csv 1,14556,43634,266,242,def,45,STATUS 12,4345,1,43,57,24,657,SD,STATUS 3,1,WQ,435,676,90,3,44f,STATUS
more file.csv
1,14556,43634,266,242,def,45,STATUS
12,4345,1,43,57,24,657,SD,STATUS
3,1,WQ,435,676,90,3,44f,STATUS
sed "/^1/ s/STATUS/OK/g" file.csv
1,14556,43634,266,242,def,45,OK
12,4345,1,43,57,24,657,SD,OK
3,1,WQ,435,676,90,3,44f,STATUS
输出应如下所示
sed ................. file.csv
1,14556,43634,266,242,def,45,OK
12,4345,1,43,57,24,657,SD,STATUS
3,1,WQ,435,676,90,3,44f,STATUS
一个解决方案:
sed“^1,/s/STATUS/OK/g”file.csv