解析某个字符串的文本文件,前缀为"Product Name:"

Rya*_*yan 2 bash grep sed

其他人我有一个脚本创建的文本文件(特别是dmidecode > dmidecode.txt),我希望能够获取"产品名称:"的内容,所以在这种情况下"HP t5740e瘦客户端",但它会略有不同机器类型.我可以使用sed计数到第44行然后将其切片直到我得到我想要的但我希望它比那更有活力.

文本文件:

41  Handle 0x0001, DMI type 1, 27 bytes
42  System Information
43      Manufacturer: Hewlett-Packard
44      Product Name: HP t5740e Thin Client
45      Version:   
46      Serial Number: CNW1160BZ7
47      UUID: A0B86400-6BBD-11E0-8325-92EEE331A344
48      Wake-up Type: Power Switch
49      SKU Number: XL424AA#ABA
50      Family: 103C_53302C
Run Code Online (Sandbox Code Playgroud)

我所拥有的代码似乎不起作用:

sed -c -i "s/\($TARGET_KEY *Product Name :*\).*/\1$REPLACEMENT_VALUE/" dmidecode.txt
Run Code Online (Sandbox Code Playgroud)

我感觉我的正则表达式已经过时了(可能是因为我看到的最初的例子污染了我的"愿景")

任何帮助是极大的赞赏!另外,任何人都知道我可以查看的任何好的正则表达式引用?

更新:好的,我可以花更多的时间在这上面,找到一些更好的例子,并从我的研究中得到这个:

grep -e "Product Name: HP" -e "Product Name: hp" dmidecode.txt | awk '{print}'
Run Code Online (Sandbox Code Playgroud)

当我添加'{print $NF}'它时只打印最后一个单词,有没有办法修改print以包含搜索字符串之后的所有内容而不是整行本身?

另外,我应该从一开始就注意到这一点,但我需要将输出转换为变量.

bpg*_*rgo 6

你甚至不需要sed

grep "Product Name" input.txt | cut -f2 -d ":"
Run Code Online (Sandbox Code Playgroud)

说明

grep "Product Name" 只给我包含"产品名称"的行

cut -f2 -d ":" 使用":"作为分隔符和返回第二个字段来分割这些行

  • 你不需要猫.只需grep"产品名称"input.txt | cust -f2 -d: (3认同)