gpt4 book ai didi

linux - 解析 XML - 从标签中减去值

转载 作者:塔克拉玛干 更新时间:2023-11-03 01:53:08 25 4
gpt4 key购买 nike

我在一个非常大的文件中有以下 xml 结构:

<sit>619709.6044;144998.7059;-090372.58119</sit>
<vll>0;0;0</vll>
<cor>255;0;255</cor>

如何减去 sit 标签中的值?该标签由三个值组成,由 ; 分隔,每个值都必须从特定数字中减去。

可以使用任何 unix 工具。 (awk、sed、bc 等)

因此,如果第一个值的特定数字是 1000,第二个值是 100,第三个值是 10,则结果将是:

<sit>618709;144898;-090362</sit>
<vll>0;0;0</vll>
<cor>255;0;255</cor>

无需保留分数。

最佳答案

这是使用 awk 的一种方法。像这样运行:

awk -v a=1000 -v b=100 -v c=10 -F "[<;>]" -v OFS=";" -f ./script.awk file

script.awk 的内容:

/^<sit>/ && /<\/sit>$/ {
$0 = "<sit>" format($3, a) OFS format($4, b) OFS format($5, c) "</sit>"
}1

function format(field, var) {
f = sub(/^-/, "", field)
return (f == 1 ? "-" : "") sprintf("%06d", int(field-var))
}

结果:

<sit>618709;144898;-090362</sit>
<vll>0;0;0</vll>
<cor>255;0;255</cor>

您还没有完全清楚如何格式化您的输出。看起来您希望用最多六个前导零填充整数,无论​​它们是正数还是负数。上面的脚本会做到这一点。如果那个零实际上是一个拼写错误,那么这个一行就足够了:

awk -v a=1000 -v b=100 -v c=10 -F "[<;>]" -v OFS=";" '/^<sit>/ && /<\/sit>$/ { $0 = "<sit>" sprintf("%06d",int($3-a)) OFS sprintf("%06d",int($4-b)) OFS sprintf("%06d",int($5-c)) "</sit>" }1' file

结果:

<sit>618709;144898;-90382</sit>
<vll>0;0;0</vll>
<cor>255;0;255</cor>

关于linux - 解析 XML - 从标签中减去值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14782581/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com