- ls
ls 命令是 linux 下最常用的命令,ls 命令就是 list 的缩写。 ls 用来打印出当前目录的清单。如果 ls 指定其他目录,那么就会显示指定目录里的文件及文件夹清单。 通过 ls 命令不仅可以查看 linux 文件夹包含的文件,而且可以查看文件权限(包括目录、文件夹、文件权限)查看目录信息等等。(1)命令格式ls [选项] [目录名](2)常用参数参数描述-a–all 列出目录下的所有文件,包括以 . 开头的隐含文件-l除了文件名之外,还将文件的权限、所有者、文件大小等信息详细列出来-d–directory 将目录象文件一样显示,而不是显示其下的文件-h–human-readable 以容易理解的格式列出文件大小 (例如 1K 234M 2G)-t以文件修改时间排序
- cd
cd / 根目录cd ~ 用户目录cd .. 父目录cd – 上一次目录
- pwd
-
Linux 中用 pwd 命令来查看“当前工作目录”的完整路径。 简单得说,每当你在终端进行操作时,你都会有一个当前工作目录。 在不太确定当前位置时,就会使用 pwd 来判定当前目录在文件系统内的确切位置。 pwd 命令是 Print Working Directory 的缩写。(1)命令格式pwd [选项](2)常用参数参数描述-P显示实际物理路径,而非使用连接(link)路径-L当目录为连接路径时,显示连接路径
-
- mv
mv 命令功能是用来移动文件或更改文件名,是 Linux 系统下常用的命令,经常用来备份文件或者目录。 mv 命令根据第二个参数类型(是目标文件还是目标目录),决定执行将文件重命名或将其移至一个新的目录中。当第二个参数类型是文件时,mv 命令完成文件重命名,此时,源文件只能有一个(也可以是源目录名),它将所给的源文件或目录重命名为给定的目标文件名。当第二个参数是已存在的目录名称时,源文件或目录参数可以有多个,mv 命令将各参数指定的源文件均移至目标目录中。 mv 命令是 move 的缩写。(1)命令格式mv [选项] 源文件或目录 目标文件或目录(2)常用参数参数描述-b –back若需覆盖文件,则覆盖前先行备份-f –force如果目标文件已经存在,不会询问而直接覆盖-i –interactive若目标文件已经存在时,就会询问是否覆盖-u –update若目标文件已经存在,且源文件比较新,才会更新-t –target该选项适用于移动多个源文件到一个目录的情况,此时目标目录在前,源文件在后
-
mkdirmkdir 命令用来创建指定名称的目录,要求创建目录的用户在当前目录中具有写权限,并且指定的目录名不能是当前目录中已有的目录。 mkdir 命令是 make directory 的缩写。(1)命令格式mkdir [选项] 目录(2)常用参数参数描述-m –mode=模式设定权限<模式>-p –parents可以是一个路径名称。若路径中的某些目录尚不存在,加上此选项后,系统将自动建立好那些尚不存在的目录,即一次可以建立多个目录-v –verbose每次创建新目录都显示信息
-
rmrm 是常用的命令,该命令的功能为删除一个目录中的一个或多个文件或目录,它也可以将某个目录及其下的所有文件及子目录均删除。对于链接文件,只是删除了链接,原有文件均保持不变。rm 是一个危险的命令,使用的时候要特别当心,尤其对于新手,否则整个系统就会毁在这个命令(比如在/(根目录)下执行 rm * -rf)。所以,我们在执行 rm 之前最好先确认一下在哪个目录,到底要删除什么东西,操作时保持高度清醒的头脑。rm 命令是 remove 的缩写。(1)命令格式rm [选项] 文件或目录(2)常用参数参数描述-f –force忽略不存在的文件,从不给出提示-i –interactive进行交互式删除-r –recursive指示 rm 将参数中列出的全部目录和子目录均递归地删除-v –verbose详细显示进行的步骤
- cp
cp 命令用来复制文件或者目录,是 Linux 系统中最常用的命令之一。一般情况下,shell 会设置一个别名,在命令行下复制文件时,如果目标文件已经存在,就会询问是否覆盖,不管你是否使用-i 参数。但是如果是在 shell 脚本中执行 cp 时,没有-i 参数时不会询问是否覆盖。这说明命令行和 shell 脚本的执行方式有些不同。 cp 命令是 copy 的缩写。(1)命令格式cp [选项] 源文件 目录 cp [选项] -t 目录 源文件(2)常用参数参数描述-t –target-directory指定目标目录-i –interactive覆盖前询问(使前面的 -n 选项失效)-n –no-clobber不要覆盖已存在的文件(使前面的 -i 选项失效)-s –symbolic-link对源文件建立符号链接,而非复制文件-f –force强行复制文件或目录, 不论目的文件或目录是否已经存在-u –update使用这项参数之后,只会在源文件的修改时间较目的文件更新时,或是对应的目的文件并不存在,才复制文件
- cat
cat 命令的功能是将文件或标准输入组合输出到标准输出。这个命令常用来显示文件内容,或者将几个文件连接起来显示,或者从标准输入读取内容并显示,它常与重定向符号配合使用。 cat 命令是 concatenate 的缩写。(1)命令格式cat [选项] [文件](2)常用参数参数描述-A –show-all等价于 -vET-b –number-nonblank对非空输出行编号-e等价于 -vE-E –show-ends在每行结束处显示 $-n –number对输出的所有行编号,由 1 开始对所有输出的行数编号-s –squeeze-blank有连续两行以上的空白行,就代换为一行的空白行-t与 -vT 等价-T –show-tabs将跳格字符显示为 ^I-u(被忽略)-v –show-nonprinting使用 ^ 和 M- 引用,除了 LFD 和 TAB 之外
- nl
-
nl 命令在 linux 系统中用来计算文件中行号。nl 可以将输出的文件内容自动的加上行号。其默认的结果与 cat -n 有点不太一样, nl 可以将行号做比较多的显示设计,包括位数与是否自动补齐 0 等等的功能。nl 命令是 number of lines 的缩写。(1)命令格式nl [选项] [文件](2)常用参数参数描述-b指定行号指定的方式,主要有两种:-b a表示不论是否为空行,也同样列出行号(类似 cat -n)-b t如果有空行,空的那一行不要列出行号(默认值)-n列出行号表示的方法,主要有三种:-n ln行号在屏幕的最左方显示-n rn行号在自己栏位的最右方显示,且不加 0-n rz行号在自己栏位的最右方显示,且加 0-w行号栏位的占用的位数
-
- more
-
more 命令,功能类似 cat ,cat 命令是将整个文件的内容从上到下显示在屏幕上。 more 命令会一页一页的显示,方便使用者逐页阅读,而最基本的指令就是按空白键(space)往下一页显示,按 b 键就会往回(back)一页显示,而且还有搜寻字串的功能 。more 命令从前向后读取文件,因此在启动时就加载整个文件。(1)命令格式more [选项] 文件(2)常用参数参数描述+n从笫 n 行开始显示-n定义屏幕大小为 n 行+/pattern在每个档案显示前搜寻该字串(pattern),然后从该字串前两行之后开始显示-c从顶部清屏,然后显示-d提示“Press space to continue,’q’ to quiet”,禁用响铃功能-p通过清除窗口而不是滚屏来对文件进行换页,与-c 选项相似-s把连续的多个空行显示为一行-u把文件内容中的下画线去掉(3)常用操作符号描述=输出当前行的行号q退出 more空格键向下滚动一屏b返回上一屏
-
- less
-
less 工具也是对文件或其它输出进行分页显示的工具,应该说是 linux 正统查看文件内容的工具,功能极其强大。(1)命令格式less [选项] 文件(2)常用参数参数描述-e当文件显示结束后,自动离开-f强迫打开特殊文件,例如外围设备代号、目录和二进制文件-i忽略搜索时的大小写-m显示类似 more 命令的百分比-N显示每行的行号-s显示连续空行为一行(3)常用操作符号描述/字符串向下搜索“字符串”的功能?字符串向上搜索“字符串”的功能n重复前一个搜索(与 / 或 ? 有关)N反向重复前一个搜索(与 / 或 ? 有关)b向前翻一页d向后翻半页q退出 less 命令空格键向后翻一页向上键向上翻动一行向下键向下翻动一行(4)常用范例less 与 cat 和 more 的区别:cat 命令功能:用于显示整个文件的内容,单独使用没有翻页功能。因此经常和 more 命令搭配使用,cat 命令还有就是可以将数个文件合并成一个文件的功能。more 命令功能:让画面在显示满一页时暂停,此时可按空格健继续显示下一个画面,或按 q 键停止显示。less 命令功能:less 命令的用法与 more 命令类似,也可以用来浏览超过一页的文件。所不同的是 less 命令除了可以按空格键向下显示文件外,还可以利用上下键来卷动文件。当要结束浏览时,只要在 less 命令的提示符“:”下按 q 键即可。其实这三个命令除了 cat 命令有合并文件的功能,其余功能上相近,只是从浏览习惯和显示方式上有所不同。
-
- which
-
which 命令的作用是,在 PATH 变量指定的路径中搜索可执行文件的所在位置。它一般用来确认系统中是否安装了指定的软件。(1)命令格式which 可执行文件名称
-
- whereis
-
whereis 命令主要用于定位可执行文件、源代码文件、帮助文件在文件系统中的位置。whereis 命令还具有搜索源代码、指定备用搜索路径和搜索不寻常项的能力。whereis 命令查找速度非常快,这是因为它根本不是在磁盘中漫无目的乱找,而是在一个数据库中(/var/lib/mlocate/)查询。这个数据库是 Linux 系统自动创建的,包含有本地所有文件的信息,并且每天通过自动执行 updatedb 命令更新一次。也正是因为这个数据库要每天才更新一次,就会使得 whereis 命令的搜索结果有时候会不准确,比如刚添加的文件可能搜不到。(1)命令格式whereis [选项] 文件(2)常用参数参数描述-b定位可执行文件-m定位帮助文件-s定位源代码文件-u搜索默认路径下除可执行文件、源代码文件、帮助文件以外的其它文件-B指定搜索可执行文件的路径-M指定搜索帮助文件的路径-S指定搜索源代码文件的路径
-
- locate 命令(ubuntu才有)
-
locate 命令跟 whereis 命令类似,且它们使用的是相同的数据库。但 whereis 命令只能搜索可执行文件、联机帮助文件和源代码文件,如果要获得更全面的搜索结果,可以使用 locate 命令。locate 命令使用了十分复杂的匹配语法,可以使用特殊字元(如’*’和’?’)来指定需要查找的样本。(1)命令格式locate [选项] [搜索字符串](2)常用参数参数描述-q安静模式,不会显示任何错误讯息-n至多显示 n 个输出-r使用正规表达式做寻找的条件-V显示版本讯息
-
- find
-
find 命令主要作用是沿着文件层次结构向下遍历,匹配符合条件的文件,并执行相应的操作。Linux 下 find 命令提供了相当多的查找条件,功能很强大,对应的学习难度也比较大。(1)命令格式find [选项] [搜索路径] [表达式]默认路径是当前目录,默认表达式为-print。表达式可能由下列成份组成:操作符、选项、测试表达式以及动作。(2)常用参数参数描述-printfind 命令将匹配的文件输出到标准输出-execfind 命令对匹配的文件执行该参数所给出的 shell 命令-name按照文件名查找文件-type查找某一类型的文件-prune使用这一选项可以使 find 命令不在当前指定的目录中查找,如果同 时使用-depth 选项,那么-prune 将被 find 命令忽略-user按照文件属主来查找文件-group按照文件所属的组来查找文件-mtime -n +n按照文件的更改时间来查找文件,-n 表示文件更改时间距现在小于 n天,+n 表示文件更改时间距现在大于 n 天,find 命令还有-atime 和 -ctime 选项
-
- xargs
-
我们可以用管道将一个命令的 stdout(标准输出)重定向到另一个命令的 stdin(标准输入)。但有些命令只能以命令行参数的形式接收数据,而无法通过 stdin 接收数据流。在这种情况下,无法通过管道将数据重定向给这些命令。这时 xargs 就可以发挥它的作用了,xargs 命令可以从标准输入接收输入,并把输入转换为一个特定的参数列表。(1)命令格式command | xargs [选项] [command]xargs 命令应该紧跟在管道操作符之后,因为它以标准输入作为主要的源数据流。(2)常用参数参数描述-n指定每行最大的参数数量-d指定分隔符(3)常用范例
-
- wc
-
wc 命令是一个统计的工具,主要用来显示文件所包含的行、字和字节数。wc 命令是 word count 的缩写。(1)命令格式wc [选项] [文件](2)常用参数参数描述-c统计字节数-l统计行数-m统计字符数,这个标志不能与 -c 标志一起使用-w统计字数,一个字被定义为由空白、跳格或换行字符分隔的字符串-L打印最长行的长度
-
- grep
-
grep 是个很强大的命令,用来找到文件中的匹配文本,并且能够接受正则表达式和通配符,同时可以用多个 grep 命令选项来生成各种格式的输出。grep 的工作方式是这样的,它在一个或多个文件中搜索字符串模板。如果模板包括空格,则必须被引用,模板后的所有字符串被看作文件名。搜索的结果被送到标准输出,不影响原文件内容。grep 可用于 shell 脚本,因为 grep 通过返回一个状态值来说明搜索的状态,如果模板搜索成功,则返回 0,如果搜索不成功,则返回 1,如果搜索的文件不存在,则返回 2。我们利用这些返回值就可进行一些自动化的文本处理工作。(1)命令格式grep [选项] pattern [file](2)常用参数参数描述-c计算找到 ‘搜寻字符串'(即 pattern) 的次数-i忽略大小写的不同,所以大小写视为相同-n输出行号-v反向选择,打印不匹配的行-r递归搜索–color=auto将找到的关键词部分加上颜色显示正则表达式是一种符号表示法,被用来识别文本模式。在某种程度上,它们与匹配文件和路径名的 shell 通配符比较相似,但其规模更大。许多命令行工具和大多数的编程语言都支持正则表达式,以此来帮助解决文本操作问题。正则表达式元字符由以下字符组成:^ $ . [ ] { } – ? * + ( ) | \
-
- cut
-
cut 命令是一个将文本按列进行切分的小工具,它可以指定分隔每列的定界符。如果一行数据包含多个字段(多列),现在想要提取其中的一列或多列,这是 cut 命令就可以大显身手了。(1)命令格式cut [选项] [文件名](2)常用参数参数描述-b以字节为单位进行分割-c以字符为单位进行分割-d自定义分隔符,默认为制表符-f自定义字段–complement抽取整个文本行,除了那些由 -c 或 -f 选项指定的文本
-
- paste
-
paste 命令的功能正好与 cut 相反。它会添加一个或多个文本列到文件中,而不是从文件中抽取文本列。它通过读取多个文件,然后把每个文件中的字段整合成单个文本流,输入到标准输出。(1)命令格式paste [选项] [文件名](2)常用参数参数描述-s将每个文件合并成行而不是按行粘贴-d自定义分隔符,默认为制表符
-
- tr
-
tr 命令常被用来更改字符。我们可以把它看作是一种基于字符的查找和替换操作。换字是一种把字符从一个字母转换为另一个字母的过程。tr 从标准输入中替换、缩减和/或删除字符,并将结果写到标准输出。tr 只能通过 stdin(标准输入),而无法通过命令行参数来接受输入。tr 是 translate(转换)的缩写。(1)命令格式tr [选项] SET1 SET2将来自 stdin 的输入字符从 SET1 映射到 SET2,并将其输出写入 stdout(标准输出)。SET1 和 SET2 是字符类或字符集。如果两个字符集的长度不相等,那么 SET2 会不断重复其最后一个字符,直到长度与 SET1 相同。如果 SET2 的长度大于 SET1,那么在 SET2 中超出 SET1 的那部分字符则全部被忽略。(2)常用参数参数描述-d删除匹配 SET1 的内容,并不作替换
-
- sort
-
同文本文件打交道时,总避不开排序,那是因为对于文本处理任务而言,排序(sort)可以起到不小的作用。sort 命令能够帮助我们对文本文件和 stdin 进行排序操作。通常,它会结合其他命令来生成所需要的输出。(1)命令格式sort [选项] [文件名](2)常用参数参数描述-n基于字符串的长度来排序,使用此选项允许根据数字值排序,而不是字母值-k指定排序关键字-b默认情况下,对整行进行排序,从每行的第一个字符开始。这个选项导致 sort 程序忽略每行开头的空格,从第一个非空白字符开始排序-m只合并多个输入文件-r按相反顺序排序,结果按照降序排列,而不是升序-t自定义分隔符,默认为制表符(3)常用范例
-
- join
-
join 命令类似于 paste,它会往文件中添加列,但是它使用了独特的方法来完成。一个 join 操作通常与关系型数据库有关联,在关系型数据库中来自多个享有共同关键域的表格的数据结合起来,得到一个期望的结果。这个 join 命令执行相同的操作,它把来自于多个基于共享关键域的文件的数据结合起来。通俗地说,就是将两个文件中指定栏位相同的行连接起来,即按照两个文件中共同拥有的某一列,将对应的行拼接成一行。(1)命令格式join [选项] 文件 1 文件 2(2)常用参数参数描述-j FIELD等同于 -1 FIELD -2 FIELD,-j 指定一个域作为匹配字段-1 FIELD以 file1 中 FIELD 字段进行匹配-2 FIELD以 file2 中 FIELD 字段进行匹配-t自定义分隔符,默认为制表符
-
- comm
-
通常比较文本文件的内容很有帮助。对于系统管理员和软件开发者来说,这个尤为重要。一名系统管理员可能,例如,需要拿现有的配置文件与先前的版本做比较,来诊断一个系统错误。同样的,一名程序员经常需要查看程序的修改。comm 命令将逐行比较已经排序的两个文件。显示结果包括 3 列:第 1 列为只在第一个文件中找到的行,第 2 列为只在第二个文件中找到的行,第 3 列为两个文件的共有行。注意,comm 命令和 join、uniq 命令一样,只能用于已经排过序的数据。(1)命令格式comm [选项] 文件 1 文件 2(2)常用参数参数描述-1不输出文件 1 特有的行-2不输出文件 2 特有的行-3不输出两个文件共有的行
-
- diff
-
类似 comm 命令,diff 命令被用来监测文件之间的差异。然而,diff 是一款更加复杂的工具,它支持许多输出格式,并且一次能处理许多文本文件。软件开发员经常使用 diff 程序来检查不同程序源码版本之间的更改,diff 能够递归地检查源码目录,经常称之为源码树。diff 程序的一个常见用例是创建 diff 文件或者补丁,它会被其它程序使用,例如 patch 程序(我们后面会讲到),来把文件从一个版本转换为另一个版本。diff 在命令行中打印每一个行的改动,并且 diff 是 svn、cvs、git 等版本控制工具不可或缺的一部分。diff 命令是 differential 的缩写。(1)命令格式diff [选项] 文件(2)常用参数参数描述-c上下文模式,显示全部内文,并标出不同之处-u统一模式,以合并的方式来显示文件内容的不同-a只会逐行比较文本文件-N在比较目录时,若文件 A 仅出现在某个目录中,预设会显示:Only in 目录。 若使用-N 参数,则 diff 会将文件 A 与一个空白的文件比较-r递归比较目录下的文件
-
- df
-
linux 中 df 命令的功能是用来检查 linux 服务器的文件系统的磁盘空间占用情况。可以利用该命令来获取硬盘被占用了多少空间,目前还剩下多少空间等信息。df 命令是 disk free 的缩写。(1)命令格式df [选项] 文件(2)常用参数参数描述-a全部文件系统列表-h方便阅读方式显示-i显示 inode 信息-T文件系统类型-t<文件系统类型>只显示选定文件系统的磁盘信息-x<文件系统类型>不显示选定文件系统的磁盘信息(3)常用范例
-
- du
-
linux 中 du 命令也是查看使用空间的,但是与 df 命令不同的是 Linux du 命令是对文件和目录磁盘使用的空间的查看。du 命令是 disk usage 的缩写。(1)命令格式du [选项] 文件(2)常用参数参数描述-a显示目录中个别文件的大小。-b显示目录或文件大小时,以 byte 为单位。-c除了显示个别目录或文件的大小外,同时也显示所有目录或文件的总和。-k以 KB(1024bytes)为单位输出。-m以 MB 为单位输出。-s仅显示总计,只列出最后加总的值。-h以 K,M,G 为单位,提高信息的可读性
-
- time
-
time 命令常用于测量一个命令的运行时间,包括实际使用时间(real time)、用户态使用时间(the process spent in user mode)、内核态使用时间(the process spent in kernel mode)。实际时间: 从 command 命令行开始执行到运行终止的时间。用户态使用时间:命令执行完成花费的用户 CPU 时间,即命令在用户态中执行时间总和。内核态使用时间:命令执行完成花费的系统 CPU 时间,即命令在核心态中执行时间总和。(1)命令格式time 命令(2)常用范例
-