当逗号用作数字组分隔符时如何使 awk 正确添加

发布于 2024-12-02 13:10:25 字数 298 浏览 0 评论 0原文

我正在尝试使用 awk 将输出文件中的数字相加,但 awk 似乎不理解分隔数千的逗号。

例如,在

awk '{if($1=="foo") {SUM+=$2}}END{print "foos ",SUM}'

foo 70.31
foo 125.00
foo 1,750.00

返回

foos 196.31

运行awk 中正确添加这些内容的最佳/适当方法是什么?

I'm trying to use awk to add up the numbers from an output file, but it seems awk doesn't understand the commas separating the thousands.

For example, running

awk '{if($1=="foo") {SUM+=$2}}END{print "foos ",SUM}'

on

foo 70.31
foo 125.00
foo 1,750.00

returns

foos 196.31

What's the best/appropriate way in awk to add these up correctly?

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

爱格式化 2024-12-09 13:10:26
awk '{if($1=="foo") {gsub(",", "", $2); SUM+=$2}}END{print "foos ",SUM}'

或者,如果您不想破坏 $2

awk '{if($1=="foo") {TERM=$2; gsub(",", "", TERM); SUM+=TERM}}END{print "foos ",SUM}'
awk '{if($1=="foo") {gsub(",", "", $2); SUM+=$2}}END{print "foos ",SUM}'

Or, if you don't want to clobber $2:

awk '{if($1=="foo") {TERM=$2; gsub(",", "", TERM); SUM+=TERM}}END{print "foos ",SUM}'
~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文