gpt4 book ai didi

linux - NTILE csv 中的一列 - Linux

转载 作者:塔克拉玛干 更新时间:2023-11-03 00:04:58 26 4
gpt4 key购买 nike

我有一个 csv 文件,内容如下:

a,b,c,2
d,e,f,3
g,h,i,3
j,k,l,4
m,n,o,5
p,q,r,6
s,t,u,7
v,w,x,8
y,z,zz,9

我想为这个数据分配五分位数(就像我们在 sql 中做的那样),最好在 linux 中使用 bash 命令。五分位数,如果分配为新列,将使最终输出看起来像:

a,b,c,2, 1
d,e,f,3, 1
g,h,i,3, 2
j,k,l,4, 2
m,n,o,5, 3
p,q,r,6, 3
s,t,u,7, 4
v,w,x,8, 4
y,z,z,9, 5

我唯一能做到的就是向 csv 文件添加一个新的增量列:

`awk '{$3=","a[$3]++}1' f1.csv > f2.csv`

但不确定五分位数如何。请帮忙。谢谢。

最佳答案

awk '{a[NR]=$0}
END{
for(i=1;i<=NR;i++) {
p=100/NR*i
q=1
if(p>20){q=2}
if(p>40){q=3}
if(p>60){q=4}
if(p>80){q=5}
print a[i] ", " q
}
}' file

输出:

a,b,c,2, 1d,e,f,3, 2g,h,i,3, 2j,k,l,4, 3m,n,o,5, 3p,q,r,6, 4s,t,u,7, 4v,w,x,8, 5y,z,zz,9, 5

关于linux - NTILE csv 中的一列 - Linux,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/48845082/

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