使用sed命令用脚本完成计数排序

计数排序是指利用空间换时间,不进行交换的排序方法。
例如有一个数组 X { 4 5 1 3 2 },想对他进行排序。
另外new一个新的空间,叫做数组Y
拿出X中第一个数字4, 统计有多少个比4小的,发现有3个,于是把4放在数组Y的第四个位置上。

首先,要排序的文件叫TestFile,目标文件叫AfterFile,也就是我们需要new一个AfterFile,所以叫用空间换时间。

[sroot@AAEP7151 shell]# cat TestFile

A:4

B:5

C:1

D:3

E:2

字母后边是序号,要按照正确的12345顺序排列。

用脚本setup.sh完成该功能。

用来排序的脚本名字叫setup.sh

[sroot@AAEP7151 shell]# cat sed.sh
在这里插入图片描述
#!/bin/bash

TestFile=/home/craft/shell/TestFile 设置绝对路径

Testcontent=cat TestFile | awk -F ':' '{print $2}'拿到第二列

for init in $Testcontent;do 对TestFile第二列的每一个元素进行遍历

temp0=$(grep $init $TestFile |awk -F: ‘{print $1}’) 拿到每一个第二列对应的第一

sed -i s/"$init"/"$temp0""$init"/g AfterFile  这个地方,sed -i表示直接对文件进行更改,sed s/要被替换的字符/新的字符串/g 表示替换字符。

done
AfterFile 里已经标号了位置序号

以A:4举例 , init=4,用sed指令,把A插到AfterFile第init,列之后,也就是第四列后

同样的把B查到第5列后,进行排序。

运行sed.sh的结果是

在这里插入图片描述

在这里插入图片描述

另外,这个功能用sort就可以实现

[sroot@AAEP7151 shell]# sort +1 -2 -n -t : TestFile

C:1

E:2

D:3

A:4

B:5

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值