bash - 在 bash 中的字母处剪切数字字符串

标签 bash shell awk cut

我有一个字符串,例如 plantford1775.274.284b63.11

我一直在使用 identity=$( echo "$identity"| cut -d'.' -f3) 在每个点处剪切,然后选择第三部分。我剩下 284b63

这部分的格式始终是一个字母,中间夹有数量不等的数字。我想取字母前的前几个数字。一个示例代码行是这样的:

identity=$( echo "$identity" | cut -d'anyletter' -f1)

我应该用什么替换 anyletter 以剪切那里列出的任何字母,以便我以字符串 284 结尾?

最佳答案

这可以在单个 awk 中完成,请尝试按照您显示的示例编写和测试。

echo "$identity" | awk -F'.' '{sub(/[^0-9].*/,"",$3);print $3}'

解释: 简单的解释是,将 echo 命令的输出作为标准输入传递给 awk 代码。在awk 程序中,将字段分隔符设置为. 作为值。然后在第 3 个字段中替换(使用 awksub 函数)除第 3 个字段中的 NULL 数字之外的所有内容,然后打印它。

关于bash - 在 bash 中的字母处剪切数字字符串,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/70572750/

相关文章:

bash - 从 PuTTY 运行的 shell 脚本返回代码到调用批处理文件?

shell - snakemake 规则调用 shell 脚本但在第一个命令后退出

firefox - 如何编写一个批处理文件,使每次在 IDE 中保存文件时 Firefox 都会刷新?

bash - AWK - 从命令行将生成的字符串作为 awk 的代码传递

java - 找不到主类: SortAlgorithms

bash - 当使用 diff 比较文本文件时,它将两个相同的文件标记为不同的,为什么?

bash - Inotifywait 子文件夹 zip 创建

linux - 从文件中计算 IP

awk - 如何从多个文件中删除模式

shell - 使用 awk 调用可执行程序