(linux shell)第二章--命令之乐(一)
文章来自于我的个人博客:(linux shell)第二章--命令之乐(一)
上一章我们描写叙述了一些linux shell中须要注意的一些语法。接下来我们開始了解linux shell的经常使用命令。let's go...
cat 命令:
cat本身表示拼接(concatenate)。cat命令有一些经常使用參数,像-n,-s等,我们以下逐一介绍:
假设你想高速查看一个文本文件内容。就能够使用cat命令:
cat file
假设你想一次查看多个文件内容。也是在后面加上文件路径就可以
cat file1 file2 file3
假设想显示文本文件的行号。则使用參数-n:
cat -n file 或者 cat -n file1 file2 file3
假设想去掉文本中的空行。则使用參数 -s:
cat -s file 或者 cat -s file1 file2 file3 当然这里也能够使用tr命令来益处空白行:cat file | tr -s ''; 这个tr命令的意思是说将多个换行符当作一个换行符来看待。
find 命令:
find命令是沿着文件层次结构向下遍历,匹配符合条件的文件,并运行对应的操作。
基本的语法:
find . -print #打印出带有路径的当前文件夹下的全部文件路径
find命令也有非常多參数,我们以下来看一些经常使用參数的使用方法:
1).依据文件名称或者正則表達式匹配搜索
find . -name "*.sh" -print #从当前文件夹查找全部符合以sh结尾的文件,并打印到终端
-name另一个相应的-iname来忽略keyword的大写和小写
find . -iname "*.sh" -print
2).依据路径匹配
find . -path "*test*" -print #从当前文件夹開始。查找路径前缀是test的全部路径以及打印出这些文件夹下的文件
3).基于正則表達式的匹配 -regex
find . -regex ".*\.py$" -print
4).否定參数 !
假设想要查找不包括条件的文件,则在类型前面加上!就可以:
find . ! -name "*.sh" -print
5).给予文件夹深度的搜索 -maxdepth 和-mindepth
我们能够通过这个命令来限制find向下查找的深度
find . -maxdepth 1 -type f -print #在当前文件夹的当前文件夹查找是文件类型的文件,也就是查找时它不会向下遍历
-maxdepth和-mindepth应该作为find的第三个參数出现,假设作为第四个或者之后的參数出现,就可能会影响到find的效率,由于 它不得不进行一些不必要的检查。
6).依据文件类型搜索 -type
find . -type d -print #仅仅列出全部的文件夹
find . -type f -print #仅仅列出全部的文件
find . -type l -print #仅仅列出全部的链接
7).依据文件的时间搜索 -mtime(改动时间) -atime(訪问时间) -ctime(变化时间),时间用+,-来表示时间的前后
find . -type f -atime -7 -print #打印出在近期7天内被訪问的全部文件
-amin(訪问时间),-mmin(改动时间),-cmin(变化时间)
find . -type f -amin +7 -print #打印出訪问时间超过7分钟的全部文件
find . -type f -newer file.sh -print #找出比file.sh改动时间更长的全部文件
8),基于文件大小的搜索 -size
find . -type f -size +2k #查找大于2KB的全部文件,除了k之外,还能够使用b--块,c--字节,w--字,M--兆字节,G--吉字节
find . -type f -size 2k #大于等于2KB的文件
find . -type f -size -2k #小于2KB的文件
9).匹配操作
find . -name "*.sh" -delete #删除匹配的全部文件(甚用)
10).基于文件权限和全部权的匹配 --perm
find . -type f -perm 644 -print #打印出权限为644的文件
11).结合find运行命令或动作
find命令能够借助选项-exec与其它命令进行结合,-exec算得上是find最强大的特性之中的一个。
find . -type f -user root -exec chown test {} \; 这个命令中,{}是一个特殊字符串,与-exec选项结合使用。对于每一个匹配的文件,{}会被替换成对应的文件名称。在上面的命令中,先查找文件所属是root用户的全部文件,然后给test用户加入权限。
find . -type f -name "*.sh" -exec cat {} \; > all_sh_files.txt 这个命令是先查出全部的sh文件。然后将文件的内容都加到文本文件里。
(linux shell)第二章--命令之乐(一)的更多相关文章
- LinuxShell脚本攻略--第二章 命令之乐
用 cat 进行拼接 文件查找与文件列表玩转 xargs 用 tr 进行转换排序临时文件命名与随机数分割文件和数据根据扩展名切分文件名mv 批量重命名文件交互输入自动化 cat: echo 'Text ...
- (linux shell)第一章--小试牛刀(上)
来源:(linux shell)第一章--小试牛刀(上) 从今天開始,我们一起来学习<linux shell脚本攻略>这本书. 1.1简单介绍 shell脚本一般是一个以#!起始的文本文件 ...
- (linux shell)第一章--小试牛刀(下)
文章来源: (linux shell)第一章--小试牛刀(下) 1.6 数组和关联数组 1.6.1 预备知识 Bash同一时候支持普通数组和关联数组.普通数组仅仅能使用整数作为数组索引,而关联数组能够 ...
- Linux Shell 05 位置变量(命令行参数)
在Linux shell 脚本中可能会用到一些命令行参数,常见如下: $0:脚本名称 $#:执行脚本时传入的参数个数,不包括脚本名称 $@:所有参数 $*:所有参数 $1...$9:第1个参数.... ...
- linux shell 操作 mysql命令(不进入mysql操作界面)
由于需要,需要将一系列mysql的操作制作成.sh文件,只需要shell操作bash命令就可以傻瓜式的完成黑盒任务. #!/bin/bash mysql -uroot -p??? -e "c ...
- linux shell实用常用命令
本文主要介绍Linux Shell的一些使用小技巧收集,非常实用,需要的朋友可以参考下. 查看本机某端口是否被占用 netstat -anpt | grep 22 查看远程某端口是否被开放 echo ...
- Linux学习《第二章命令》本章小结
经过这一章的学习,了解了常用的命令.这是学习Linux系统最最基础的工作,必须努力掌握,个人觉得,并不是这个章节学习结束之后,命令的学习就结束了,而是刚刚开始,今后在每个知识点学习过程中,都会 学习到 ...
- Linux课后练习(第二章命令)20200218
- Linux学习-第二章(命令)20200216
随机推荐
- IntelliJ 、Pycharm、webstorm 2017 注册码及注册服务器
jetbrains 家的东西都非常好看,但是价格贵的令人发指,所以我搭建了一个 Pycharm激活服务器,可以用来激活 Pycharm,IntelliJ IDEA,WebStorm.避免频繁更换激活码 ...
- react篇章-React 组件-ES6 class 来定义一个组件
<!DOCTYPE html> <html> <head> <meta charset="UTF-8" /> <title&g ...
- 如何对富文本编辑器(FCK Html Editor)的工具栏进行扩展?
我们在项目开发过程中,会经常使用到富文本编辑器.GeneXus内置的富文本编辑器FCK Html Editor使用起来非常方便,只要将页面变量的控件类型(Control Type)选择为FCK Htm ...
- innerText和innerHTML, outerHTML
js中 innerHTML与innerText的用法与区别及解决Firefox不支持Js的InnerHtml问题 用法: <div id="test"> <spa ...
- FastReport.Net使用:[10]报表栏目说明
报表栏目说明 报表标题(Report Title):在每个报表的开始时打印. 报表合计区(Report Summary):在报表结尾时打印,显示在最后一行数据后,页脚前. 页眉(Page Header ...
- [BZOJ4521][CQOI2016]手机号码(数位DP)
4521: [Cqoi2016]手机号码 Time Limit: 10 Sec Memory Limit: 512 MBSubmit: 875 Solved: 507[Submit][Status ...
- 不思议迷宫:逆向后的放置play
前言 前置准备 目标分析 逆向加密逻辑 定位sign与key 解密luac 反编译luajit的bytecode 开启上帝模式 前言 看了fatezero的<阴阳师:一个非酋的逆向旅程& ...
- 【8.20校内测试】【DP】【二分+贪心】
一开始想的贪心,可是发现贪心的问题太多了啊!只能保证当前最优,全局完全无法考虑. 所以正解是dp.预处理出前缀和,枚举每个区间,在每个点记录$now[i]$表示以$i$这个塔结尾的塔组目前的高度.$d ...
- bzoj 1468
大概思路:树点分治,重心树中每个重心维护一个总的平衡树,树中保存属于该重心的点到该重心的距离,然后对于去掉该重心后形成的子树分别再保存一份. 用这种方式实现的话,还可以支持修改与多次查询,每次操作都是 ...
- 某DP题目1
题意: 有n个由左右括号组成的字符串,选择其中若干字符串,使得组成的括号序列合法且长度最长.n <= 1000,n个字符串的长度和 <= 10000. 分析: 其实我一开始做这一题的时候, ...