博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
20145239 Linux下常用的ls命令总结
阅读量:5292 次
发布时间:2019-06-14

本文共 3205 字,大约阅读时间需要 10 分钟。

20145239 Linux下常用的ls命令总结

      通过学习本周的教学视频和要求掌握的内容,发现ls命令被使用的次数非常多,但作为一个初学者,可能我只会ls或者顶多ls -l两种用法。但其实ls是一个非常实用的指令,因此我想简单的总结一下ls的常用命令。

  • ls,英文全名:list 即列表的意思。

常用命令(以本周的10io文件夹为例):

1. ls -a 列出文件下所有的文件,包括以“.“开头的隐藏文件(linux下文件隐藏文件是以.开头的,如果存在..代表存在着父目录)。

 

2. ls -l 列出文件的详细信息,如创建者,创建时间,文件的读写权限列表等等。

 

3. ls -F 在每一个文件的末尾加上一个字符说明该文件的类型。"@"表示符号链接、"|"表示FIFOS、"/"表示目录、"="表示套接字。

 

4. ls -s 在每个文件的后面打印出文件的大小。 size(大小)

 

5. ls -t 按时间进行文件的排序。 time(时间)

 

6. ls -A 列出除了"."和".."以外的文件。

 

7. ls -R 将目录下所有的子目录的文件都列出来,相当于我们编程中的“递归”实现。

 

8. ls -L 列出文件的链接名。Link(链接)

 

9. ls -S 以文件的大小进行排序

 

文件颜色含义:

绿色---->代表可执行文件

红色---->代表压缩文件
深蓝色---->代表目录
浅蓝色----->代表链接文件
灰色---->代表其它的一些文件

 

所有ls命令列举:

以下是几乎所有ls命令的选项,很多可能并不常用但可以作为了解。

      -a 列出目录下的所有文件,包括以 . 开头的隐含文件。 

  -b 把文件名中不可输出的字符用反斜杠加字符编号(就象在C语言里一样)的形式列出。 
  -c 输出文件的 i 节点的修改时间,并以此排序。 
  -d 将目录象文件一样显示,而不是显示其下的文件。 
  -e 输出时间的全部信息,而不是输出简略信息。 
  -f -U 对输出的文件不排序。 
  -i 输出文件的 i 节点的索引信息。 
  -k 以 k 字节的形式表示文件的大小。 
  -l 列出文件的详细信息。 
  -m 横向输出文件名,并以“,”作分格符。 
  -n 用数字的 UID,GID 代替名称。 
  -o 显示文件的除组信息外的详细信息。 
  -p -F 在每个文件名后附上一个字符以说明该文件的类型,“*”表示可执行的普通 
          文件;“/”表示目录;“@”表示符号链接;“|”表示FIFOs;“=”表示套接字。
  -q 用?代替不可输出的字符。 
  -r 对目录反向排序。 
  -s 在每个文件名后输出该文件的大小。 
  -t 以时间排序。 
  -u 以文件上次被访问的时间排序。 
  -x 按列输出,横向排序。 
  -A 显示除 “.”和“..”外的所有文件。 
  -B 不输出以 “~”结尾的备份文件。 
  -C 按列输出,纵向排序。 
  -G 输出文件的组的信息。 
  -L 列出链接文件名而不是链接到的文件。 
  -N 不限制文件长度。 
  -Q 把输出的文件名用双引号括起来。 
  -R 列出所有子目录下的文件。 
  -S 以文件大小排序。 
  -X 以文件的扩展名(最后一个 . 后的字符)排序。 
  -1 一行只输出一个文件。 
  --color=no 不显示彩色文件名 
  --help 在标准输出上显示帮助信息。 
  --version 在标准输出上输出版本信息并退出。

自己编写ls命令:

其实ls命令是可以自己编写的,但我在自己尝试编写ls命令时发现还是有困难,对许多函数的理解不到位。这里提供一个可以运行的自己编写的ls命令的代码,可以供大家学习参考。

#include 
#include
#include
#include
#include
#include
#include
#include
#include
#include
int fun1(char *dir,char *filename){ struct stat buf; char out[100]; if(stat(dir,&buf)<0) { perror("stat"); return (-1); } switch(buf.st_mode & S_IFMT) { case S_IFREG: printf("-"); break; case S_IFDIR: printf("d"); break; case S_IFCHR: printf("c"); break; case S_IFBLK: printf("b"); break; case S_IFIFO: printf("p"); break; case S_IFLNK: printf("l"); break; case S_IFSOCK: printf("s"); break; } int n; for(n=8;n>=0;n--) { if(buf.st_mode&(1<
pw_name); struct group *gr; gr = getgrgid(buf.st_gid); printf(" %s",gr->gr_name); printf(" %ld",buf.st_size); struct tm *t; t = localtime(&buf.st_atime); printf(" %d-%d-%d %d:%d",t->tm_year+1900, t->tm_mon+1, t->tm_mday, t->tm_hour, t->tm_min); printf(" %s ",filename); if(S_ISLNK(buf.st_mode)) { printf(" -> "); if(readlink(filename,out,100)==-1) { } printf("%s",out); } printf("\n"); return 0;}int main(int argc ,char **argv){ char w[100]; memset(w,0,100); if(argc<2) strcpy(w,"./"); else strcpy(w,argv[1]); struct stat buf; char name[100]; if(stat(w,&buf)<0) { fprintf(stderr,"stat error:%s\n",strerror(errno)); return -1; } if(S_ISDIR(buf.st_mode)) { DIR *dir; dir = opendir(w); struct dirent *pdr; while ((pdr = readdir(dir))!=NULL) { if(pdr->d_name[0]=='.') { } else { printf(" dir:%s \n",pdr->d_name); memset(name,0,100); strcpy(name,w); // strcat(name,"/"); strcat(name,pdr->d_name); fun1(name,pdr->d_name); } } } else { fun1(w,w); } return 0;}

运行结果:

转载于:https://www.cnblogs.com/dwc929210354/p/6082345.html

你可能感兴趣的文章
DP学习之路(1) 01背包
查看>>
获取元素样式信息于三中获取方式的区别
查看>>
测试主要环节
查看>>
08-17工作总结
查看>>
遇麻烦,Win7+Ubuntu12.10+Archlinux12.10 +grub
查看>>
基本高精度模板
查看>>
SqlBulkCopy大批量导入数据
查看>>
Windows Workflow Foundation 入门
查看>>
LaTeX 中图片格式错误情况
查看>>
Sublime Text 3 Build 3065 License key 注册码 秘钥
查看>>
AngularJS中transclude用法详解
查看>>
Sliding Menu Demos 浅析:Sliding Title Bar 与 Sliding Content Only
查看>>
java利用freemarker导出world
查看>>
简单的弹出拖拽窗口(二)
查看>>
LeetCode题解之 Assign Cookies
查看>>
第八周编程总结
查看>>
Java-----思想认识
查看>>
ASP.NET - TreeView控件,只操作最后一级节点
查看>>
设计模式示例系列随笔
查看>>
HTTP协议概述
查看>>