[英]Command to fetch 2nd line of xml file and rename the file with fetched name
我有一个名为media.xml的xml文件,它包含:
<?xml version="1.0" encoding="UTF-8" standalone="no"?>
<table name="advisoryTable"/>
<row>
<field name="book">maths</field>
<field name="book">science</field>
<field name="book">eng</field>
</row>
</table>
有什么办法可以从xml文件中提取"advisory table"
名称,并将文件从media.xml重命名为advisory.xml。
先感谢您
我希望您的<table>
元素实际上不是自动关闭的,因此您的XML有效。 如果是这样,您可以使用诸如xmllint
的工具来提取name
属性的值:
xmllint --xpath 'string(/table/@name)' media.xml
该命令的输出为advisoryTable
。 您可以将输出通过管道传递到sed,以删除Table
部分:
xmllint --xpath 'string(/table/@name)' media.xml | sed 's/Table//'
如果您对结果满意,可以在命令替换中使用它来重命名文件:
mv media.xml "$(xmllint --xpath 'string(/table/@name)' media.xml | sed 's/Table//')"
我不愿意鼓励以这种方式自动重命名文件,因为这样可能会导致意外覆盖某些内容。 也许最好改为复制文件,可以使用cp -n
避免破坏已经存在的具有相同名称的文件。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.