AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / unix / 问题

问题[numeric-data](unix)

Martin Hope
Chap
Asked: 2022-07-10 14:35:47 +0800 CST

如何对具有不同数据类型的多个列使用排序

  • 1

这是我的制表符分隔文件 t.tsv:

$ cat t.tsv
2022/05/05  -258.03
2022/05/07  -18.10
2022/05/09  -10.74
2022/05/09  -132.60
2022/05/12  -18.56
2022/05/12  -20.20
2022/05/17  -11.00
2022/05/17  -112.91
2022/05/17  -51.43
2022/05/17  -64.78
2022/05/18  -13.96
2022/05/18  -13.96
2022/05/18  -7.51
2022/05/19  -17.08
2022/05/20  -33.08

我正在使用 MacOS 12.4 排序(来自手册页:排序实用程序符合 IEEE Std 1003.1-2008 (“POSIX.1”) 规范)首先按 alpha seq 升序按 col 1 排序,然后按数字升序按 col2 排序。

$ cat t.tsv|sort --field-separator='\t' --key=1,1 --key=2,2n
2022/05/05  -258.03
2022/05/07  -18.10
2022/05/09  -10.74
2022/05/09  -132.60
2022/05/12  -18.56
2022/05/12  -20.20
2022/05/17  -11.00
2022/05/17  -112.91
2022/05/17  -51.43
2022/05/17  -64.78
2022/05/18  -13.96
2022/05/18  -13.96
2022/05/18  -7.51
2022/05/19  -17.08
2022/05/20  -33.08

我很困惑为什么当第一列相同时,第二列没有按升序数字顺序排序。许多 SE 对同一问题的回答都说(a)您将单个列指定为--key=1,1,并且(b)您可以将选项-n应用于单个键定义,例如--key=2,2n.

更新:我应该提到我的外壳是bash.

sort numeric-data
  • 1 个回答
  • 49 Views
Martin Hope
Joey
Asked: 2022-06-19 02:30:44 +0800 CST

如何仅显示 XML 文件中开始和结束标记之间的内容?

  • 0

如何使用 grep 或类似方法在 XML 文件中搜索特定标签,但仅显示开始标签和结束标签之间的内容?这是我想找到的确切标签:

<max-diskusage>1024000000</max-diskusage>

但我只想得到 1024000000 部分而不是标签。

这是一个以字节为单位的存储大小,并将其转换为 1 gb IF POSSIBLE 或任何转换为​​ GB 的结果。

xml numeric-data
  • 1 个回答
  • 16 Views
Martin Hope
Veak
Asked: 2021-12-24 09:22:48 +0800 CST

将数字与 glob 模式匹配

  • 0

我正在尝试使用 glob 模式进行匹配。但是在使用的时候就失败了 myfun 12。

dgt='^+([0123456789])$'
[[ "$1" == $dgt  ]] && echo "SUCCESS" || echo "FAILURE"
bash numeric-data
  • 2 个回答
  • 1003 Views
Martin Hope
user495498
Asked: 2021-11-16 19:15:36 +0800 CST

“sort -n”和“sort -g”有什么区别?

  • 2

-n这两个排序选项和有什么区别-g?

有太多细节但没有足够的文档有点令人困惑。

sort numeric-data
  • 1 个回答
  • 278 Views
Martin Hope
schrodingerscatcuriosity
Asked: 2021-11-12 03:51:30 +0800 CST

链接在一起的两个范围之间的随机数输出

  • 4

这个问题是关于在一个范围之间生成随机数,这很好,但它不适合我的情况。

我将用 SQL 术语进行解释,因为在我看来这更容易理解,尽管问题是关于bash. 我的想法是用bash代码的结果构建一个 SQL 脚本。

我有两张 MySQL 表,一张是人,一张是地方。每条记录都有一个唯一的整数 id,从 1 到 139(地点)和 1 到 1519(人)。它们通过外键相互链接,意思是:一个地方可以有很多人,但一个人只能有一个地方。

# 1-139  # 1-1519
place1 → person1
       → person2
       → person3
       ... and so on

我现在拥有的数据是,在一个地方所有的人都联系在一起,而其他地方没有任何联系。

名额是139,人是1519,所以我有一个地方1519人。

我的目标是将人员随机分配到各个地方,并且每个地方至少有一个人。

到目前为止,我的代码是这样的:

$ c=1519
$ while [[ $c -ne 0 ]]; do 
    x=$((shuf -i 1-139 -n 1))
    [[ $x -gt 139 ]] && continue
    echo $x
    (( c-- ))
  done

此代码生成 1-139 之间的 1519 个随机数,因此现在我可以将每个人链接到一个随机位置。

我的问题是:

  • 有没有更有效的方法来实现这一点?
  • 如何控制每个地方至少有一个人?

我更喜欢在 中执行此操作bash,但我对其他不涉及它的解决方案持开放态度。

bash numeric-data
  • 3 个回答
  • 646 Views
Martin Hope
user1050619
Asked: 2020-01-15 13:04:21 +0800 CST

排序数值列

  • 4

我正在尝试根据特定位置对文件进行排序,但这不起作用,这是数据和输出。

~/scratch$ cat  id_researchers_2018_sample 
id - 884209 , researchers - 1
id - 896781 , researchers - 4
id - 901026 , researchers - 15
id - 904091 , researchers - 1
id - 905525 , researchers - 1
id - 908660 , researchers - 5
id - 908876 , researchers - 7
id - 910480 , researchers - 10
id - 916197 , researchers - 1
~/scratch$ sort  -k 28,5 id_researchers_2018_sample 
id - 884209 , researchers - 1
id - 896781 , researchers - 4
id - 901026 , researchers - 15
id - 904091 , researchers - 1
id - 905525 , researchers - 1
id - 908660 , researchers - 5
id - 908876 , researchers - 7
id - 910480 , researchers - 10
id - 916197 , researchers - 1

我想按最后一列中的数字对其进行排序,如下所示:

id - 884209 , researchers - 1
id - 904091 , researchers - 1
id - 905525 , researchers - 1
id - 916197 , researchers - 1
id - 896781 , researchers - 4
id - 908660 , researchers - 5
id - 908876 , researchers - 7
id - 910480 , researchers - 10
id - 901026 , researchers - 15
sort numeric-data
  • 2 个回答
  • 664 Views
Martin Hope
yael
Asked: 2020-01-01 03:56:52 +0800 CST

对所有出现参数的值求和

  • -1

我们有以下文件,

在文件中,我们可以看到相同的参数名称及其值

more file.txt

gg_ff_rr =56
gg_ff_rr =56
gg_ff_rr =52
jk_ll_tt=24
jk_ll_tt=24
jk_ll_tt=24
pl_pl_uu=10
pl_pl_uu=8
pl_pl_uu=10
ww_ee_qq=2
ww_ee_qq=2
ww_ee_qq=1
oo_pp_ww=10
oo_pp_ww=10
mm_mm_bb=1
AA_AA_AA=1
AA_AA_AA=1
AA_AA_AA=1
AA_AA_AA=1
.
.
.
.

我们计划将所有出现参数的值相加,因此预期的输出将是这样的

gg_ff_rr=164
jk_ll_tt=72
pl_pl_uu=28
ww_ee_qq==5
oo_pp_ww=20
mm_mm_bb=1
AA_AA_AA=4
.
.
.
.

如何使用 bash/awk/shell-script 或 Perl 单行来完成

我们尝试以下

awk -F= '{a[$1]+=$2;}END{for(i in a){print i "=" a[i]}}'  /tmp/file.txt

macafi___pp___export___weer 100=0
macafi___pp___my_name___gtp___state 100=0
macafi___pp___my_name___gtp___enr 100=0
macafi___pp___trw___initial___mixed 100=0
macafi___pp___my_name___broad 100=0
macafi___pp___adc___voip___stat 100=0
macafi___pp___my_name___gtp 300=0
macafi___pp___trw___initial 200=0

虽然文件是这样的

more /tmp/file.txt

macafi___pp___my_name___broad 100
macafi___pp___my_name___gtp 300
macafi___pp___my_name___gtp___enr 100
macafi___pp___my_name___gtp___state 100
macafi___pp___adc___voip___stat 100
macafi___pp___export___weer 100
macafi___pp___trw___initial 200
macafi___pp___trw___initial___mixed 100
macafi___pp___trw___initial___mixed 100
macafi___pp___trw___initial___mixed 100
awk numeric-data
  • 1 个回答
  • 62 Views
Martin Hope
alekhine
Asked: 2019-08-01 04:30:47 +0800 CST

为一系列变量和条件列添加多行到文件

  • 0

我有一个包含 4 列的文件。前两列用于 x 和 y 位置(整数),第三、四列用于任意字段值。

1 1 0.5 1.2 
1 2 1.7 2.3
1 3 2.0 2.2 
2 1 1.4 2.5
2 2 1.6 3.0
2 3 2.35 2.9
3 1 2.0 2.9
3 2 0.7 2.5
3 3 0.2 2.1

对于这个输入文件,我想在第二列和第三列之间添加两列对于前两列中 x,y 的每个值,从 1 到 3 的 az 值应添加为第三列。最后,应该在第四列中添加一个值,使得

if (z<$3 ) value = 0
if (z>=$3 && z <=$4) value = 1
if (z >$4) value = 2

注意 $3 是 $4 是输入文件中的列值,$4 总是大于 $3。

输出文件应如下所示

1 1 1 1 0.5 1.2 
1 1 2 2 0.5 1.2 
1 1 3 2 0.5 1.2 
1 2 1 0 1.7 2.3
1 2 2 1 1.7 2.3
1 2 3 2 1.7 2.3    
1 3 1 0 2.0 2.2 
1 3 2 1 2.0 2.2
1 3 3 2 2.0 2.2
2 1 1 2 1.4 2.5
2 1 2 2 1.4 2.5
2 1 3 2 1.4 2.5
2 2 1 0 1.6 3.0
2 2 2 1 1.6 3.0
2 2 3 1 1.6 3.0
2 3 1 0 2.35 2.9
2 3 2 0 2.35 2.9
2 3 3 2 2.35 2.9
3 1 1 0 2.0 2.9
3 1 2 1 2.0 2.9
3 1 3 2 2.0 2.9
3 2 1 1 0.7 2.5
3 2 2 1 0.7 2.5
3 2 3 2 0.7 2.5
3 3 1 1 0.2 2.1
3 3 2 1 0.2 2.1
3 3 3 2 0.2 2.1

如何用 awk 创建这样的输出文件?

awk numeric-data
  • 1 个回答
  • 72 Views
Martin Hope
αԋɱҽԃ αмєяιcαη
Asked: 2019-05-12 22:31:39 +0800 CST

修剪 jq 提取的数字的尾随零

  • 6

以下命令通过BTC从特定交易所获取价格来实现我的目标。

curl -sS https://api.binance.com/api/v1/ticker/price?symbol=BTCUSDT | jq -r '.price'

输出暂时是,7222.25000000但我想得到它7222.25

jq numeric-data
  • 3 个回答
  • 1738 Views
Martin Hope
Priya
Asked: 2019-05-11 16:06:00 +0800 CST

如何按降序对第二列进行排序?[复制]

  • 1
这个问题在这里已经有了答案:
如何按浮点数对行进行排序 1 个回答
3年前关闭。

我想根据第二列按降序对输入文件进行排序。我为此使用了以下命令:

sort -k2,2nr input.txt > output.txt

但是,在运行命令后,我得到了这个输出:

ENSG00000273451 2.46335345019054e-05
ENSG00000181374 1.05269640687115e-05
ENSG00000182150 1.01285751909085e-05
ENSG00000283697 1
ENSG00000283463 0.932309672567822
ENSG00000157916 0.845034568173369
ENSG00000268983 0.835243646448564
ENSG00000227251 0.834326032498057
ENSG00000140157 0.833074569385573
ENSG00000134882 0.832993129338477

预期的输出应该是

ENSG00000283697 1
ENSG00000283463 0.932309673
ENSG00000157916 0.845034568
ENSG00000268983 0.835243646
ENSG00000227251 0.834326032
ENSG00000140157 0.833074569
ENSG00000134882 0.832993129
ENSG00000273451 2.46E-05
ENSG00000181374 1.05E-05
ENSG00000182150 1.01E-05
sort numeric-data
  • 1 个回答
  • 8069 Views

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    模块 i915 可能缺少固件 /lib/firmware/i915/*

    • 3 个回答
  • Marko Smith

    无法获取 jessie backports 存储库

    • 4 个回答
  • Marko Smith

    如何将 GPG 私钥和公钥导出到文件

    • 4 个回答
  • Marko Smith

    我们如何运行存储在变量中的命令?

    • 5 个回答
  • Marko Smith

    如何配置 systemd-resolved 和 systemd-networkd 以使用本地 DNS 服务器来解析本地域和远程 DNS 服务器来解析远程域?

    • 3 个回答
  • Marko Smith

    dist-upgrade 后 Kali Linux 中的 apt-get update 错误 [重复]

    • 2 个回答
  • Marko Smith

    如何从 systemctl 服务日志中查看最新的 x 行

    • 5 个回答
  • Marko Smith

    Nano - 跳转到文件末尾

    • 8 个回答
  • Marko Smith

    grub 错误:你需要先加载内核

    • 4 个回答
  • Marko Smith

    如何下载软件包而不是使用 apt-get 命令安装它?

    • 7 个回答
  • Martin Hope
    user12345 无法获取 jessie backports 存储库 2019-03-27 04:39:28 +0800 CST
  • Martin Hope
    Carl 为什么大多数 systemd 示例都包含 WantedBy=multi-user.target? 2019-03-15 11:49:25 +0800 CST
  • Martin Hope
    rocky 如何将 GPG 私钥和公钥导出到文件 2018-11-16 05:36:15 +0800 CST
  • Martin Hope
    Evan Carroll systemctl 状态显示:“状态:降级” 2018-06-03 18:48:17 +0800 CST
  • Martin Hope
    Tim 我们如何运行存储在变量中的命令? 2018-05-21 04:46:29 +0800 CST
  • Martin Hope
    Ankur S 为什么 /dev/null 是一个文件?为什么它的功能不作为一个简单的程序来实现? 2018-04-17 07:28:04 +0800 CST
  • Martin Hope
    user3191334 如何从 systemctl 服务日志中查看最新的 x 行 2018-02-07 00:14:16 +0800 CST
  • Martin Hope
    Marko Pacak Nano - 跳转到文件末尾 2018-02-01 01:53:03 +0800 CST
  • Martin Hope
    Kidburla 为什么真假这么大? 2018-01-26 12:14:47 +0800 CST
  • Martin Hope
    Christos Baziotis 在一个巨大的(70GB)、一行、文本文件中替换字符串 2017-12-30 06:58:33 +0800 CST

热门标签

linux bash debian shell-script text-processing ubuntu centos shell awk ssh

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve