Warning: file_get_contents(/data/phpspider/zhask/data//catemap/2/linux/25.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Linux sed-如何精确匹配行中的数字_Linux_Sed - Fatal编程技术网

Linux 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

请给出建议,如何告诉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


  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