歡迎來到Linux教程網
Linux教程網
Linux教程網
Linux教程網
您现在的位置: Linux教程網 >> UnixLinux >  >> Linux基礎 >> 關於Linux

.bashrc文件 使用教程

~/.bashrc文件決定了交互shell的行為. 好好的了解這個文件, 將會使你更加了解Bash.

Emmanuel Rouat捐獻了下邊這個注釋非常詳細的.bashrc文件, 這個文件是為Linux系統編寫的. 他希望讀者能夠給他一些回饋.

仔細的學習這個文件, 直到你可以自由重用其中的代碼片斷和函數, 並把它們用到你自己的.bashrc文件中, 甚至可以放到你的腳本中.

例子 K-1. .bashrc文件樣本

1 #=============================================================== 2 # 3 # 個人的$HOME/.bashrc文件, 基於bash-2.05a(或更高版本) 4 # 5 # 最後更新日期: 星期2 4月15 20:32:34 CEST 2003 6 # 7 # 這個文件(一般情況下)被只會被交互式shell讀取. 8 # 這裡可以定義你的別名, 函數, 9 # 和其他的一些交互式特征, 比如你的提示符. 10 # 11 # 這個文件(開始時)是為Solaris設計的, 12 # 但是基於Redhat的默認.bashrc文件 13 # --> 為Linux修改. 14 # 你在這裡看到的大部分代碼都是從網上找來的 15 # (即internet). 16 # 這個bashrc文件有點擠 - 17 # 記住, 它僅僅是個例子而已. 按照你自己的需求進行裁減. 18 # 19 # 20 #=============================================================== 21 22 # --> 注釋由HOWTO的作者添加. 23 # --> 然後又被ER編輯了一下 :-) 24 25 #-------------------------------------- 26 # 如果有源代碼的全局定義, 請在此處定義. 27 #-------------------------------------- 28 29 if [ -f /etc/bashrc ]; then 30 . /etc/bashrc # --> 讀取/etc/bashrc, 如果存在的話. 31 fi 32 33 #------------------------------------------------------------- 34 # $DISPLAY的自動設置 (如果還沒設置的話) 35 # 這用於linux - 可能運行的結果不同.... 36 # 問題是不同的終端種類對於'who am i'來說, 37 # 將會給出不同的答案...... 38 # 我還沒發現一種'通用'方法 39 #------------------------------------------------------------- 40 41 function get_xserver () 42 { 43 case $TERM in 44 xterm ) 45 XSERVER=$(who am i | awk '{print $NF}' | tr -d ')''(' ) 46 # Ane-Pieter Wieringa建議使用下面這種方式: 47 # I_AM=$(who am i) 48 # SERVER=${I_AM#*(} 49 # SERVER=${SERVER%*)} 50 51 XSERVER=${XSERVER%%:*} 52 ;; 53 aterm | rxvt) 54 # 找出一些運行在這裡的代碼..... 55 ;; 56 esac 57 } 58 59 if [ -z ${DISPLAY:=""} ]; then 60 get_xserver 61 if [[ -z ${XSERVER} || ${XSERVER} == $(hostname) || ${XSERVER} == "unix" ]]; then 62 DISPLAY=":0.0" # 在本地主機上顯示 63 else 64 DISPLAY=${XSERVER}:0.0 # 在遠端主機上顯示 65 fi 66 fi 67 68 export DISPLAY 69 70 #---------- 71 # 一些設置 72 #---------- 73 74 ulimit -S -c 0 # 不需要任何coredump 75 set -o notify 76 set -o noclobber 77 set -o ignoreeof 78 set -o nounset 79 #set -o xtrace # 對於調試來說非常有用 80 81 # 使能選項: 82 shopt -s cdspell 83 shopt -s cdable_vars 84 shopt -s checkhash 85 shopt -s checkwinsize 86 shopt -s mailwarn 87 shopt -s sourcepath 88 shopt -s no_empty_cmd_completion # 僅限於bash>=2.04 89 shopt -s cmdhist 90 shopt -s histappend histreedit histverify 91 shopt -s extglob # 對於complete命令(按情況補全)來說是必要的 92 93 # 禁用選項: 94 shopt -u mailwarn 95 unset MAILCHECK # 當有郵件到達時, 我不希望我的shell提示我 96 97 98 export TIMEFORMAT=$'\nreal %3R\tuser %3U\tsys %3S\tpcpu %P\n' 99 export HISTIGNORE="&:bg:fg:ll:h"100 export HOSTFILE=$HOME/.hosts # 將遠端主機的列表放入~/.hosts101 102 103 104 #-----------------------105 # 問候, 問侯報文等等...106 #-----------------------107 108 # 先定義一些顏色:109 red='\e[0;31m'110 RED='\e[1;31m'111 blue='\e[0;34m'112 BLUE='\e[1;34m'113 cyan='\e[0;36m'114 CYAN='\e[1;36m'115 NC='\e[0m' # 沒有顏色116 # --> 很好. 與使用"ansi.sys"的DOS效果相同. 117 118 # 在黑色背景下看起來非常好.....119 echo -e "${CYAN}This is BASH ${RED}${BASH_VERSION%.*}${CYAN} - DISPLAY on ${RED}$DISPLAY${NC}\n"120 date121 if [ -x /usr/games/fortune ]; then122 /usr/games/fortune -s # 讓我們的每天充滿樂趣.... :-)123 fi124 125 function _exit() # 在退出shell時運行的函數126 {127 echo -e "${RED}Hasta la vista, baby${NC}"128 }129 trap _exit EXIT130 131 #---------------132 # Shell提示符133 #---------------134 135 if [[ "${DISPLAY#$HOST}" != ":0.0" && "${DISPLAY}" != ":0" ]]; then 136 HILIT=${red} # 遠端主機: 提示符為紅137 else138 HILIT=${cyan} # 本地主機: 提示符為青色139 fi140 141 # --> 下面提示符函數中\W和\w的替換實例, 142 #+ --> 用來獲得完整路徑名的顯示. 143 144 function fastprompt()145 {146 unset PROMPT_COMMAND147 case $TERM in148 *term | rxvt )149 PS1="${HILIT}[\h]$NC \W > \[\033]0;\${TERM} [\u@\h] \w\007\]" ;;150 linux )151 PS1="${HILIT}[\h]$NC \W > " ;;152 *)153 PS1="[\h] \W > " ;;154 esac155 }156 157 function powerprompt()158 {159 _powerprompt()160 {161 LOAD=$(uptime|sed -e "s/.*: \([^,]*\).*/\1/" -e "s/ //g")162 }163 164 PROMPT_COMMAND=_powerprompt165 case $TERM in166 *term | rxvt )167 PS1="${HILIT}[\A \$LOAD]$NC\n[\h \#] \W > \[\033]0;\${TERM} [\u@\h] \w\007\]" ;;168 linux )169 PS1="${HILIT}[\A - \$LOAD]$NC\n[\h \#] \w > " ;;170 * )171 PS1="[\A - \$LOAD]\n[\h \#] \w > " ;;172 esac173 }174 175 powerprompt # 這是默認提示符 - 可能比較慢176 # 如果很慢的話, 可以使用fastprompt來代替....177 178 #===============================================================179 #180 # 別名和函數181 #182 # 事實上, 這裡定義的一些函數非常大183 # (比如'lowercase'), 但是我的機器是512M內存, 所以 .....184 # 如果你想讓這個文件小一點, 185 # 可以將這些函數放到腳本中. 186 #187 # 其中的許多函數來自於bash-2.04188 # 中的例子. 189 #190 #===============================================================191 192 #-------------------193 # 個人的別名194 #-------------------195 196 alias rm='rm -i'197 alias cp='cp -i'198 alias mv='mv -i'199 # -> 防止偶然的文件誤操作. 200 alias mkdir='mkdir -p'201 202 alias h='history'203 alias j='jobs -l'204 alias r='rlogin'205 alias which='type -all'206 alias ..='cd ..'207 alias path='echo -e ${PATH//:/\\n}'208 alias print='/usr/bin/lp -o nobanner -d $LPDEST' # 假設LPDEST被定義209 alias pjet='enscript -h -G -fCourier9 -d $LPDEST' # 使用enscript的漂亮的打印210 alias background='xv -root -quit -max -rmode 5' # 將一張圖片作為背景211 alias du='du -kh'212 alias df='df -kTh'213 214 # 'ls'家族 (假定使用GNU ls)215 alias la='ls -Al' # 顯示隱藏文件216 alias ls='ls -hF --color' # 為識別的文件類型添加顏色217 alias lx='ls -lXB' # 按擴展名排序218 alias lk='ls -lSr' # 按尺寸排序219 alias lc='ls -lcr' # 按修改時間排序220 alias lu='ls -lur' # 按訪問時間排序221 alias lr='ls -lR' # 遞歸ls222 alias lt='ls -ltr' # 按日期排序223 alias lm='ls -al |more' # 管道給'more'224 alias tree='tree -Csu' # 'ls'的另一種好方法225 226 # 裁減'less'227 alias more='less'228 export PAGER=less229 export LESSCHARSET='latin1'230 export LESSOPEN='|/usr/bin/lesspipe.sh %s 2>&-' # 如果lesspipe.sh存在, 就用這個231 export LESS='-i -N -w -z-4 -g -e -M -X -F -R -P%t?f%f \232 :stdin .?pb%pb\%:?lbLine %lb:?bbByte %bb:-...'233 234 # 拼寫錯誤 - 純粹個人喜好 :-)235 alias xs='cd'236 alias vf='cd'237 alias moer='more'238 alias moew='more'239 alias kk='ll'240 241 #----------------242 # 一些有趣東西243 #----------------244 245 function xtitle ()246 {247 case "$TERM" in248 *term | rxvt)249 echo -n -e "\033]0;$*\007" ;;250 *) 251 ;;252 esac253 }254 255 # 別名...256 alias top='xtitle Processes on $HOST && top'257 alias make='xtitle Making $(basename $PWD) ; make'258 alias ncftp="xtitle ncFTP ; ncftp"259 260 # .. 和函數261 function man ()262 {263 for i ; do264 xtitle The $(basename $1|tr -d .[:digit:]) manual265 command man -F -a "$i"266 done267 }268 269 function ll(){ ls -l "$@"| egrep "^d" ; ls -lXB "$@" 2>&-| egrep -v "^d|total "; }270 function te() # xemacs/gnuserv的包裝器271 {272 if [ "$(gnuclient -batch -eval t 2>&-)" == "t" ]; then273 gnuclient -q "$@";274 else275 ( xemacs "$@" &);276 fi277 }278 279 #---------------------------280 # 與文件和字符串相關的函數:281 #---------------------------282 283 # 使用名字模式來查找文件:284 function ff() { find . -type f -iname '*'$*'*' -ls ; }285 # 使用pattern $1和Execute $2來查找文件: 286 function fe() { find . -type f -iname '*'$1'*' -exec "${2:-file}" {} \; ; }287 # 在一系列文件中找到模式, 並高亮288 function fstr()289 {290 OPTIND=1291 local case=""292 local usage="fstr: find string in files.293 Usage: fstr [-i] \"pattern\" [\"filename pattern\"] "294 while getopts :it opt295 do296 case "$opt" in297 i) case="-i " ;;298 *) echo "$usage"; return;;299 esac300 done301 shift $(( $OPTIND - 1 ))302 if [ "$#" -lt 1 ]; then303 echo "$usage"304 return;305 fi306 local SMSO=$(tput smso)307 local RMSO=$(tput rmso)308 find . -type f -name "${2:-*}" -print0 | xargs -0 grep -sn ${case} "$1" 2>&- | \309 sed "s/$1/${SMSO}\0${RMSO}/gI" | more310 }311 312 function cuttail() # 在文件中切掉n行, 默認為10行313 {314 nlines=${2:-10}315 sed -n -e :a -e "1,${nlines}!{P;N;D;};N;ba" $1316 }317 318 function lowercase() # 將文件名轉換為小寫319 {320 for file ; do321 filename=${file##*/}322 case "$filename" in323 */*) dirname==${file%/*} ;;324 *) dirname=.;;325 esac326 nf=$(echo $filename | tr A-Z a-z)327 newname="${dirname}/${nf}"328 if [ "$nf" != "$filename" ]; then329 mv "$file" "$newname"330 echo "lowercase: $file --> $newname"331 else332 echo "lowercase: $file not changed."333 fi334 done335 }336 337 function swap() # 交換兩個文件名338 {339 local TMPFILE=tmp.$$340 mv "$1" $TMPFILE341 mv "$2" "$1"342 mv $TMPFILE "$2"343 }344 345 346 #----------------------347 # 進程/系統相關的函數:348 #----------------------349 350 function my_ps() { ps $@ -u $USER -o pid,%cpu,%mem,bsdtime,command ; }351 function pp() { my_ps f | awk '!/awk/ && $0~var' var=${1:-".*"} ; }352 353 # 這個函數與linux上的'killall'基本一致354 # 但是與Solaris上的卻不相同355 function killps() # 按進程名進行kill356 {357 local pid pname sig="-TERM" # 默認signal358 if [ "$#" -lt 1 ] || [ "$#" -gt 2 ]; then359 echo "Usage: killps [-SIGNAL] pattern"360 return;361 fi362 if [ $# = 2 ]; then sig=$1 ; fi363 for pid in $(my_ps| awk '!/awk/ && $0~pat { print $1 }' pat=${!#} ) ; do364 pname=$(my_ps | awk '$1~var { print $5 }' var=$pid )365 if ask "Kill process $pid <$pname> with signal $sig?"366 then kill $sig $pid367 fi368 done369 }370 371 function my_ip() # 獲得IP地址372 {373 MY_IP=$(/sbin/ifconfig ppp0 | awk '/inet/ { print $2 } ' | sed -e s/addr://)374 MY_ISP=$(/sbin/ifconfig ppp0 | awk '/P-t-P/ { print $3 } ' | sed -e s/P-t-P://)375 }376 377 function ii() # 獲得當前主機相關的信息378 {379 echo -e "\nYou are logged on ${RED}$HOST"380 echo -e "\nAdditionnal information:$NC " ; uname -a381 echo -e "\n${RED}Users logged on:$NC " ; w -h382 echo -e "\n${RED}Current date :$NC " ; date383 echo -e "\n${RED}Machine stats :$NC " ; uptime384 echo -e "\n${RED}Memory stats :$NC " ; free385 my_ip 2>&- ;386 echo -e "\n${RED}Local IP Address :$NC" ; echo ${MY_IP:-"Not connected"}387 echo -e "\n${RED}ISP Address :$NC" ; echo ${MY_ISP:-"Not connected"}388 echo389 }390 391 # 雜項工具:392 393 function repeat() # 重復n次的命令394 {395 local i max396 max=$1; shift;397 for ((i=1; i <= max ; i++)); do # --> C風格的語法398 eval "$@";399 done400 }401 402 function ask()403 {404 echo -n "$@" '[y/n] ' ; read ans405 case "$ans" in406 y*|Y*) return 0 ;;407 *) return 1 ;;408 esac409 }410 411 #=========================================================================412 #413 # 按情況補全, complete命令 - BASH-2.04及其後續版本414 # 大部分摘自bash 2.05文檔415 # 和Ian McDonalds的'Bash completion'軟件包(http://www.caliban.org/bash/index.shtml#completion)416 # 某些特征可能需要使用bash-2.05a417 #418 #=========================================================================419 420 if [ "${BASH_VERSION%.*}" \< "2.05" ]; then421 echo "You will need to upgrade to version 2.05 for programmable completion"422 return423 fi424 425 shopt -s extglob # 必須的426 set +o nounset # 否則某些自動補全將會失敗427 428 complete -A hostname rsh rcp telnet rlogin r ftp ping disk429 complete -A export printenv430 complete -A variable export local readonly unset431 complete -A enabled builtin432 complete -A alias alias unalias433 complete -A function function434 complete -A user su mail finger435 436 complete -A helptopic help # 通常與內建命令一樣437 complete -A shopt shopt438 complete -A stopped -P '%' bg439 complete -A job -P '%' fg jobs disown440 441 complete -A directory mkdir rmdir442 complete -A directory -o default cd443 444 # 壓縮445 complete -f -o default -X '*.+(zip|ZIP)' zip446 complete -f -o default -X '!*.+(zip|ZIP)' unzip447 complete -f -o default -X '*.+(z|Z)' compress448 complete -f -o default -X '!*.+(z|Z)' uncompress449 complete -f -o default -X '*.+(gz|GZ)' gzip450 complete -f -o default -X '!*.+(gz|GZ)' gunzip451 complete -f -o default -X '*.+(bz2|BZ2)' bzip2452 complete -f -o default -X '!*.+(bz2|BZ2)' bunzip2453 # Postscript,pdf,dvi.....(譯者: 打印格式相關)454 complete -f -o default -X '!*.ps' gs ghostview ps2pdf ps2ascii455 complete -f -o default -X '!*.dvi' dvips dvipdf xdvi dviselect dvitype456 complete -f -o default -X '!*.pdf' acroread pdf2ps457 complete -f -o default -X '!*.+(pdf|ps)' gv458 complete -f -o default -X '!*.texi*' makeinfo texi2dvi texi2html texi2pdf459 complete -f -o default -X '!*.tex' tex latex slitex460 complete -f -o default -X '!*.lyx' lyx461 complete -f -o default -X '!*.+(htm*|HTM*)' lynx html2ps462 # 多媒體463 complete -f -o default -X '!*.+(jp*g|gif|xpm|png|bmp)' xv gimp464 complete -f -o default -X '!*.+(mp3|MP3)' mpg123 mpg321465 complete -f -o default -X '!*.+(ogg|OGG)' ogg123466 467 468 469 complete -f -o default -X '!*.pl' perl perl5470 471 # 這是一個'通用的'補全函數 - 當命令具有一個所謂的"長選項"模式it works when commands have472 # 的時候, 它就會工作, 比如: 'ls --all' 代替 'ls -a'473 474 _get_longopts () 475 { 476 $1 --help | sed -e '/--/!d' -e 's/.*--\([^[:space:].,]*\).*/--\1/'| \477 grep ^"$2" |sort -u ;478 }479 480 _longopts_func ()481 {482 case "${2:-*}" in483 -*) ;;484 *) return ;;485 esac486 487 case "$1" in488 \~*) eval cmd="$1" ;;489 *) cmd="$1" ;;490 esac491 COMPREPLY=( $(_get_longopts ${1} ${2} ) )492 }493 complete -o default -F _longopts_func configure bash494 complete -o default -F _longopts_func wget id info a2ps ls recode495 496 497 _make_targets ()498 {499 local mdef makef gcmd cur prev i500 501 COMPREPLY=()502 cur=${COMP_WORDS[COMP_CWORD]}503 prev=${COMP_WORDS[COMP_CWORD-1]}504 505 # 如果之前的參數為-f, 那就返回可能的補全文件名. 506 # 我們可以讓它更智能一些, 並且返回匹配的507 # `makefile Makefile *.mk', 不管存在與否508 case "$prev" in509 -*f) COMPREPLY=( $(compgen -f $cur ) ); return 0;;510 esac511 512 # 如果我們需要一個選項, 那就返回可能的posix選項513 case "$cur" in514 -) COMPREPLY=(-e -f -i -k -n -p -q -r -S -s -t); return 0;;515 esac516 517 # 前嘗試`makefile'再嘗試`Makefile'518 if [ -f makefile ]; then519 mdef=makefile520 elif [ -f Makefile ]; then521 mdef=Makefile522 else523 mdef=*.mk # 局部約定524 fi525 526 # 在我們掃描目標文件之前, 察看makefile文件名是否527 # 使用-f指定528 for (( i=0; i < ${#COMP_WORDS[@]}; i++ )); do529 if [[ ${COMP_WORDS[i]} == -*f ]]; then530 eval makef=${COMP_WORDS[i+1]} # eval for tilde expansion(波浪號擴展)531 break532 fi533 done534 535 [ -z "$makef" ] && makef=$mdef536 537 # 如果我們有特別偏愛的補全單詞, 538 # 那麼可以限制的補全這個單詞539 if [ -n "$2" ]; then gcmd='grep "^$2"' ; else gcmd=cat ; fi540 541 # 如果我們不想使用*.mk, 我們可以使用542 # 或者使用test -f $makef或者使用輸入重定向543 COMPREPLY=( $(cat $makef 2>/dev/null | awk 'BEGIN {FS=":"} /^[^.# ][^=]*:/ {print $1}' | tr -s ' ' '\012' | sort -u | eval $gcmd ) )544 }545 546 complete -F _make_targets -X '+($*|*.[cho])' make gmake pmake547 548 549 # cvs(1) 補全550 _cvs ()551 {552 local cur prev553 COMPREPLY=()554 cur=${COMP_WORDS[COMP_CWORD]}555 prev=${COMP_WORDS[COMP_CWORD-1]}556 557 if [ $COMP_CWORD -eq 1 ] || [ "${prev:0:1}" = "-" ]; then558 COMPREPLY=( $( compgen -W 'add admin checkout commit diff \559 export history import log rdiff release remove rtag status \560 tag update' $cur ))561 else562 COMPREPLY=( $( compgen -f $cur ))563 fi564 return 0565 }566 complete -F _cvs cvs567 568 _killall ()569 {570 local cur prev571 COMPREPLY=()572 cur=${COMP_WORDS[COMP_CWORD]}573 574 # 獲得進程列表(第一個sed表達式處理575 # swap out出去的進程, 第二個576 # 獲得進程的basename)577 COMPREPLY=( $( /usr/bin/ps -u $USER -o comm | \578 sed -e '1,1d' -e 's#[]\[]##g' -e 's#^.*/##'| \579 awk '{if ($0 ~ /^'$cur'/) print $0}' ))580 581 return 0582 }583 584 complete -F _killall killall killps585 586 587 # 一個元命令補全函數, 用於sudo(8)這種命令, 588 # 需要先對這個命令進行補全, 然後需要按照這個命令自己的補全定義進行補全589 # - 當前並不是非常可靠(比如 mount和umount命令590 # 就不能很好的工作), 但還是很有用的 - 作者, Ian McDonald, 我修改了一下. 591 592 _my_command()593 {594 local cur func cline cspec595 596 COMPREPLY=()597 cur=${COMP_WORDS[COMP_CWORD]}598 599 if [ $COMP_CWORD = 1 ]; then600 COMPREPLY=( $( compgen -c $cur ) )601 elif complete -p ${COMP_WORDS[1]} &>/dev/null; then602 cspec=$( complete -p ${COMP_WORDS[1]} )603 if [ "${cspec%%-F *}" != "${cspec}" ]; then604 # complete -F <function>605 #606 # COMP_CWORD和COMP_WORDS()不是只讀的,607 # 所以我們可以在傳遞到補全例程之前, 608 # 設置它們609 610 # 設置當前的標志號減1611 COMP_CWORD=$(( $COMP_CWORD - 1 ))612 # 獲得函數名613 func=${cspec#*-F }614 func=${func%% *}615 # 獲得去掉第一個命令後的命令行616 cline="${COMP_LINE#$1 }"617 # 分離當前命令, 傳遞給數組618 COMP_WORDS=( $cline )619 $func $cline620 elif [ "${cspec#*-[abcdefgjkvu]}" != "" ]; then621 # complete -[abcdefgjkvu]622 #func=$( echo $cspec | sed -e 's/^.*\(-[abcdefgjkvu]\).*$/\1/' )623 func=$( echo $cspec | sed -e 's/^complete//' -e 's/[^ ]*$//' )624 COMPREPLY=( $( eval compgen $func $cur ) )625 elif [ "${cspec#*-A}" != "$cspec" ]; then626 # complete -A <type>627 func=${cspec#*-A }628 func=${func%% *}629 COMPREPLY=( $( compgen -A $func $cur ) )630 fi631 else632 COMPREPLY=( $( compgen -f $cur ) )633 fi634 }635 636 637 complete -o default -F _my_command nohup exec eval trace truss strace sotruss gdb638 complete -o default -F _my_command command type which man nice639 640 # 本地變量:641 # mode:shell-script642 # sh-shell:bash643 # End:
 

Copyright © Linux教程網 All Rights Reserved