sort命令的学习与实践
一、用man sort 查看sort的帮助文档
*sort将文件的每一行作为一个单位,相互比较,比较原则是从首字符向后,依次按ASCII码值进行比较,最后将他们按升序输出。
[rocrocket@rocrocket programming]$ cat seq.txt
banana
apple
pear
orange
[rocrocket@rocrocket programming]$ sort seq.txt
apple
banana
orange
pear
二、sort常用选项有哪些,都有什么功能?提交相关使用的截图
选项:
-b:忽略前面空格。
-c:测试文件是否已经排序。
-d:根据字典顺序排序,仅比较数字 字母 空格等字符。
-f:忽略大小写。
-i:仅比较可打印字符。
-n:纯数字排列
-R:根据哈希值随机排序。
-r:反向,颠倒顺序。
-k:定义排序关键字。原来的:第几个区间,与t相辅。
-t:分隔符
-m:仅仅合并已经排序好的文件,不执行排序操作。
-s:稳定的排序算法。
-o:排序结果写入文件,而不是标准输出到设备。
-u:相同的行只留一行
-M:月份
使用截图:
源文件:
Sort -b test1.txt:忽略前面空格
我们可以看见空格的影响消失了。
Sort -r test1.txt:反向,颠倒顺序
Sort -n test1.txt :纯数字排序
Sort -u test1.txt:相同的行只留一行
我们可以看见,相同的只剩一个。
空格也算作字符。
4 sort的-o选项
由于sort默认是把结果输出到标准输出,所以需要用重定向才能将结果写入文件,形如sort filename > newfile。
但是,如果你想把排序结果输出到原文件中,用重定向可就不行了。
Sort -r filename -o newfilename
sort -r test1.txt -o t.txt
我们查看t.txt文件:
Sort --help:查看帮助文档
一、如果让你编写sort,你怎么实现?写出伪代码和相关的函数或系统调用
我的sort实现过程:
1、打开文件(fopen指令),通过一个指针char *file打开指向的文件,打开成功则指向该文件的指针返回,失败则返回NULL。
fopen(filename/url,mode) 这两个参数是必选的,第一个文件名/url,第二个打开的方式
$handle = fopen($filename,'r');
打开方式常用的有以下几种:
r - 只读方式打开,将文件指针指向文件头
r+ - 读写方式打开,将文件指针指向文件头
w - 写入方式打开,将文件指针指向文件头并将文件大小截为零。如果文件不存在则尝试创建之
w+ -读写方式打开,将文件指针指向文件头并将文件大小截为零。如果文件不存在则尝试创建之
a -写入方式打开,将文件指针指向文件末尾。如果文件不存在则尝试创建之
a+ -读写方式打开,将文件指针指向文件末尾。如果文件不存在则尝试创建之
2、读取文件:使用fread函数
fread函数可从文件中读取二进制数据
语法:
A = fread(fid, count)
A = fread(fid, count, precision)
其中fid为指针所指文件中的当前位置,count指读取的数据个数, precision表示以什么格式的数据类型读取数据。
3、调用sort函数进行排序
I)Sort函数有三个参数:
(1)第一个是要排序的数组的起始地址。
(2)第二个是结束的地址(最后一位要排序的地址)
(3)第三个参数是排序的方法,可以是从大到小也可是从小到大,还可以不写第三个参数,此时默认的排序方法是从小到大排序。
4、将排序后的新数据重定向写入文件中(write),可以写入新文件也可以覆盖原文件。
5、关闭文件:fclose
fclose()用来关闭fopen()打开的文件,此动作会让缓冲区内的数据写入文件中,并释放系统所提供的文件资源。
【返回值】若关文件动作成功则返回0,有错误发生时则返回EOF,并把错误代码存到errno。