⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 linux shell简介.htm

📁 linuxSir 网站的精华文章
💻 HTM
📖 第 1 页 / 共 5 页
字号:
      <P>第二个通配符是问号(question 
      mark):'?'。在匹配时,一个问号只能代表一个字符。为了示范其用途,我们在上例的假设中添加两个新文件:'311.bak~'和'some.text'。现在,列出所有在点号后有四个字符的文件:<BR>
      <DIV class=codeblock><CODE>ls *.????</CODE></DIV>
      <P></P>
      <P>问号通配符能够有效地避免上面提到的'取反号陷阱'(negation trap):<BR>
      <DIV class=codeblock><CODE>rm *[!4]?.*</CODE></DIV>
      <P></P>
      <P>将扩展成"所有除了点号前倒数第二个字符为'4'的文件",也就是只保留文件'346.bak'。</P>
      <P>您可能会问,有没有其他匹配方式?到目前为止,您只看到了在指定位置匹配唯一字符的方法。但其实您也可以这样:<BR>
      <DIV class=codeblock><CODE>ls [13]*</CODE></DIV>
      <P></P>
      <P>将列出所有以字符'1'或'3'开头的文件;在我们的例子中,文件'124.bak'、'311.bak~'和'346.bak'匹配。注意到您必须用中括号将匹配的模式括起来,否则模式只匹配以字符串'13'开头的文件。</P>
      <P>接下来,您将高兴地看到还可以定义匹配的范围:<BR>
      <DIV class=codeblock><CODE>ls *[3-8]?.*</CODE></DIV>
      <P></P>
      <P>将列出所有点号前倒数第二个字符落在'3'到'8'范围的文件。在我们的例子中,匹配的文件是'346.bak'和'583.bak'。<BR><FONT 
      id=4.2 size=4><B><BR>二、引用 shell 的特殊字符<BR></B></FONT></P>
      <P>但是,上面的那些机制存在一个缺点:shell 总在命令执行前,试着进行扩展。有时候,会变得很棘手:<BR>
      <DIV class=codeblock><CODE>l 
      文件名包含特殊字符。假设您在那个目录中还有一个名为'!56.bak'的文件。下面试图进行模式匹配:<BR>rm !*<BR>rm<BR>rm: 
      too few arguments</CODE></DIV>
      <P></P>
      <P>shell 将'!*'解释成历史记录的替换(加入前一个命令的所有参数),而不是匹配方式。</P>
      <P>l 命令本身带特殊字符作参数。一些 Linux 下的命令行工具,比如 (e)grep、sed、awk、find 及 locate 
      ,都使用自己的正则表达式(regular expressions)。这些表达式与模式匹配看起来惊人地相似,但在某些地方又有所不同。</P>
      <P>但为了使这些特殊命令生效,shell 就不能先将其当作模式匹配来解释:<BR>
      <DIV class=codeblock><CODE>find . -name [1-9]* -print<BR>find: paths must 
      precede expression</CODE></DIV><BR>应该是:<BR>
      <DIV class=codeblock><CODE>find . -name '[1-9]*' 
      -print<BR>./346.bak<BR>./124.bak<BR>./583.bak<BR>./311.bak~</CODE></DIV>
      <P></P>
      <P>您可以通过反斜线(back slash)来引用特殊字符,比如 ! 、$ 、? 或空格:<BR>
      <DIV class=codeblock><CODE>ls \!*<BR>!56.bak</CODE></DIV>
      <P></P>
      <P>或者用(单)引号:<BR>
      <DIV class=codeblock><CODE>ls '!'*<BR>!56.bak</CODE></DIV>
      <P></P>
      <P>请注意,要看清楚引号应该放在什么位置。命令 ls '!*' 
      将查找名为'!*'的文件,这是由于通配符也在引号间,所以只能依照字面来解释。<BR><FONT id=4.3 
      size=4><B><BR>三、输出重定向<BR></B></FONT></P>
      <P>Unix 的理念是汇集许多小程序,每个东东都有特殊的专长。复杂的任务不是由大型软件完成,而是运用 shell 
      的机制,组合许多小程序共同完成。重定向就在其中发挥着重要的作用。<BR><FONT id=4.31 
      size=3><B><BR>1、在多个命令间重定向<BR></B></FONT></P>
      <P>这要通过管道(pipe),由管道符号|来标识。语法是:<BR>
      <DIV class=codeblock><CODE>command1 | command2 | command3 等等</CODE></DIV>
      <P></P>
      <P>这种格式您一定已经见到过了。管道经常将一个程序的输出送到'more'或'less'来阅读。<BR>
      <DIV class=codeblock><CODE>ls -l | less</CODE></DIV>
      <P></P>
      <P>其中,第一个命令提供目录内容,第二个则将其以翻页的方式显示。更复杂的例子如:<BR>
      <DIV class=codeblock><CODE>rpm -qa | grep ^x | less</CODE></DIV>
      <P></P>
      <P>第一个命令给出所有已安装的 RPM 
      包,第二个则将其过滤(filter:'grep'),只剩下以'^x'开头的包,第三个命令则将结果以翻页的方式显示。</P>
      <P><FONT id=4.32 size=3><B><BR>2、重定向至文件<BR></B></FONT></P>
      <P>有时,您希望将命令的输出结果保存到文件中,或以文件内容作为命令的参数。这可以通过'&gt;'和'&lt;'来实现。<BR>
      <DIV class=codeblock><CODE>command &gt; file</CODE></DIV>
      <P></P>
      <P>将 command 的输出保存到 file 中,这将覆盖 file 中的内容:<BR>
      <DIV class=codeblock><CODE>ls &gt; dirlist</CODE></DIV>
      <P></P>
      <P>将当前目录的内容保存到'dirlist'文件。<BR>
      <DIV class=codeblock><CODE>command &lt; file</CODE></DIV>
      <P></P>
      <P>将 file 内容作为 command 的输入:<BR>
      <DIV class=codeblock><CODE>sort &lt; dirlist &gt; sdirlist</CODE></DIV>
      <P></P>
      <P>将文件'dirlist'的内容送到命令'sort',然后再将排序后的结果送到文件'sdirlist'。当然,您也可以一步到位:<BR>
      <DIV class=codeblock><CODE>ls | sort &gt; sdirlist</CODE></DIV>
      <P></P>
      <P>一种特殊的方式是'command 2&gt; file'。这将 command 执行的出错信息送到 file 
中。这个您到时候会需要……</P>
      <P>另一种操作符是'&gt;&gt;',这将输出添加到已存在的文件中:<BR>
      <DIV class=codeblock><CODE>echo "string" &gt;&gt; file</CODE></DIV>
      <P></P>
      <P>将 string 加到文件 file 中。这是不打开文件而完成编辑的好办法!</P>
      <P>但是,'&lt;'和'&gt;'操作符都有一个重要的限制:<BR>
      <DIV class=codeblock><CODE>command &lt; file1 &gt; file1</CODE></DIV>
      <P></P>
      <P>将删除 file1 的内容,而<BR>
      <DIV class=codeblock><CODE>command &lt; file1 &gt;&gt; file1</CODE></DIV>
      <P></P>
      <P>却可以很好地工作,将加工过的 file1 内容加回到文件中。</P>
      <P>是不是有点多?;-) 不必惊慌,您完全可以按照自己的速度,一步步地来学习。别忘了,实践是最好的学习方法……</P>
      <P>熟知了许多 shell 的机制后, 您可能急着想知道如何来定制环境。在后面的两篇中,您将得到这方面的启示。在最后一篇中,还有一段如何处理 
      shell 出错信息的常见问答(FAQ),及一些配置技巧。</P>
      <P><FONT id=5 size=4><B>第五篇:bash 配置文件/提示符/改变 $PATH</B></FONT></P>
      <P><FONT id=5.1 size=5><B><BR>一、bash 配置文件<BR></B></FONT></P>
      <P>在您的 home 目录下,运行<BR>
      <DIV class=codeblock><CODE>ls .bash*</CODE></DIV><BR>您将看到这些文件:<BR>
      <DIV class=codeblock><CODE>l .bash_history :记录了您以前输入的命令,<BR>l .bash_logout 
      :当您退出 shell 时,要执行的命令,<BR>l .bash_profile :当您登入 shell 时,要执行的命令,<BR>l 
      .bashrc :每次打开新的 shell 时,要执行的命令。</CODE></DIV>
      <P></P>
      <P>请注意后两个的区别:'.bash_profile'只在会话开始时被读取一次,而'.bashrc'则每次打开新的终端(如新的 xterm 
      窗口)时,都要被读取。按照传统,您得将定义的变量,如 PATH ,放到'.bash_profile'中,而象 
      aliases(别名)和函数之类,则放在'.bashrc'。但由于'.bash_profile'经常被设置成先读取'.bashrc'的内容,您如果图省事的话,就把所有配置都放进'.bashrc'。</P>
      <P>这些文件是每一位用户的设置。系统级的设置存储在'/etc/profile'、'/etc/bashrc'及目录'/etc/profile.d'下的文件中。但您得习惯用各自的配置文件:编辑不需要'root'权限,还可以使您的设置更有个性。当系统级与用户级的设置发生冲突时,将采用用户的设置。</P>
      <P>读取'.bashrc'的内容,您如果要省点事的话,就把您所有的配置都放进'.bashrc'。</P>
      <P>上面的这些文件是每位用户的设置,系统级的设置存储在'/etc/profile'、'/etc/bashrc'及目录'/etc/profile.d'下的文件中。您最好习惯使用各自的配置文件:编辑不需要'root'权限,还可以使您的设置更具个性。当系统级与用户级的设置发生冲突时,将优先采用用户的设置。<BR><FONT 
      id=5.2 size=4><B><BR>二、提示符<BR></B></FONT></P>
      <P>每次当您打开一个控制台(console)或 xterm 时,最先看到的就是提示符(prompt),类似于:<BR>
      <DIV class=codeblock><CODE>account@hostname ~ $</CODE></DIV>
      <P></P>
      <P>在默认设置下,提示符将显示您的用户名、主机名(默认是'localhost')、当前所在目录(在 Unix 中,'~'表示您的 home 
      目录)。</P>
      <P>按照传统,最后一个字符可以标识您是普通用户($),还是'root'(#)。</P>
      <P>您可以通过 $PS1 变量来设置提示符。命令<BR>
      <DIV class=codeblock><CODE>echo $PS1</CODE></DIV>
      <P></P>
      <P>将显示当前的设定。其中可用字符的含义在 man bash 的'PROMPTING'部分有说明。</P>
      <P>如何才能完成理想的设置呢?对于健忘的初学者来讲,默认设定有些不友好,因为提示符只显示当前目录的最后一部分。如果您看到象这样的提示符<BR>
      <DIV class=codeblock><CODE>tom@localhost bin $</CODE></DIV>
      <P></P>
      <P>您的当前目录可能是'/bin'、'/usr/bin'、'/usr/local/bin'及'/usr/X11R6/bin'。当然,您可以用</P>
      <P>pwd (输出当前目录,print working directory)</P>
      <P>能不能叫 shell 自动告诉您当前目录呢?</P>
      <P>当然可以。这里我将提到的设定,包括提示符,大都包含在文件'/etc/bashrc'中。您可以通过编辑各自 home 
      目录下的'.bash_profile'和'.bashrc'来改变设置。</P>
      <P>在 man bash 
      中的'PROMPTING'部分,对这些参数(parameter)有详细说明。您可以加入一些小玩意,如不同格式的当前时间,命令的历史记录号,甚至不同的颜色。</P>
      <P>在'~/.bashrc'中,我喜欢的设定是:<BR>
      <DIV class=codeblock><CODE>PS1="\[\033[1m\][\w]\[\033[0m\] 
      "</CODE></DIV><BR>'root'在'~/.bashrc'中的设定 是:<BR>
      <DIV class=codeblock><CODE>PS1="\[\033[0;31m\][\w]\[\033[0m\] 
      "</CODE></DIV>
      <P></P>
      <P>这样我得到的提示符就是:<BR>
      <DIV class=codeblock><CODE>[/usr/bin]</CODE></DIV>
      <P></P>
      <P>当用'root'时,变成:<BR>
      <DIV 
      class=codeblock><CODE>[/usr/bin]</CODE></DIV><BR>我已经除掉了主机名和用户名,因为我用不着这些。但我首先想一眼就能看出我的身份是普通用户还是'root'。注意到,普通用户的提示符可以是黑底白字,或白底黑字。
      <P></P>
      <P>要在终端上获得恰当的颜色调配, 您可以编辑下面这个脚本color ,赋予执行权限(chmod +x color),然后再运行。<BR>
      <DIV class=codeblock><CODE>#!/bin/bash<BR>#<BR># This file echoes a bunch 
      of color codes to the<BR># terminal to demonstrate what's available. 
      Each<BR># line is the color code of one forground color,<BR># out of 17 
      (default + 16 escapes), followed by a<BR># test use of that color on all 
      nine background<BR># colors (default + 8 escapes).<BR>#<BR>T='gYw' # The 
      test text<BR>echo -e "\n 40m 41m 42m 
      43m\<BR>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;44m 45m 46m 47m";<BR>for FGs in ' m' 
      ' 1m' ' 30m' '1;30m' ' 31m' '1;31m' ' 32m' 
      \<BR>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;'1;32m' 
      ' 33m' '1;33m' ' 34m' '1;34m' ' 35m' '1;35m' 
      \<BR>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;' 
      36m' '1;36m' ' 37m' '1;37m';<BR>&nbsp;&nbsp;do FG=${FGs// 
      /}<BR>&nbsp;&nbsp;echo -en " $FGs \033[$FG $T "<BR>&nbsp;&nbsp;for BG in 
      40m 41m 42m 43m 44m 45m 46m 47m;<BR>&nbsp;&nbsp;&nbsp;&nbsp;do echo -en 
      "$EINS \033[$FG\033[$BG $T 
      \033[0m";<BR>&nbsp;&nbsp;done<BR>&nbsp;&nbsp;echo;<BR>done<BR>echo</CODE></DIV>
      <P></P>
      <P>一种更适当的设定:<BR>
      <DIV class=codeblock><CODE>PS1="\u: \w\\$ "</CODE></DIV><BR>这样,提示符就变成:<BR>
      <DIV class=codeblock><CODE>user_name: /usr/bin$</CODE></DIV>
      <P></P>

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -