जवाबों:
यह इस उत्तर!!
में उल्लिखित चाल पर कुछ विस्तार करता है । वास्तव में इतिहास से संबंधित आदेशों का एक समूह होता है, जिनके बारे में लोग भूल जाते हैं (लोग एक बार आदेश के लिए खोजते हैं कि वे जिस टाइप को जानते हैं, उसे ढूंढते हैं)।Up
history
आदेश बाईं ओर एक घटना डेसिग्नेटर साथ हाल ही में चलाने के आदेशों की सूची दिखाएगा!N
ईवेंट डिज़ाइनर से जुड़ी कमांड को बदलेगा N
!-N
विकल्प होगा N
वें सबसे हाल ही में आदेश; उदा !-1
सबसे हालिया कमांड, !-2
दूसरा सबसे हाल का विकल्प, आदि स्थानापन्न करेगा ।!!
है !-1
, अंतिम आदेश को जल्दी से प्रतिस्थापित करने के लिए शॉर्टहैंड है!string
सबसे हालिया आदेश को प्रतिस्थापित करेगा जो इसके साथ शुरू होता है string
!?string?
सबसे हालिया कमांड को सम्मिलित करेगा जिसमें सम्मिलित है string
!
परिणामों को संशोधित करने के लिए वर्ड डिजाइनर्स को एक हिस्ट्री कमांड पर जोड़ा जा सकता है । एक बृहदान्त्र घटना और शब्द पदनाम, जैसे को अलग करता है !!:0
। इवेंट डिज़ाइनर !!
को केवल !
शब्द डिज़ाइनर का उपयोग करते समय संक्षिप्त किया जा सकता है , इसलिए !!:0
इसके बराबर है !:0
।
!:0
निष्पादित की गई कमांड मिलेगी!:1
पहला तर्क मिलेगा (और !:2
दूसरा, आदि)!:2-3
दूसरा और तीसरा तर्क मिलेगा!:^
पहला तर्क प्राप्त करने का एक और तरीका है। !:$
आखिरी मिलेगा!:*
सभी तर्क मिलेंगे (लेकिन कमांड नहीं )मॉडिफ़ायर को एक !
इतिहास कमांड में भी जोड़ा जा सकता है , प्रत्येक एक कोलन द्वारा उपसर्ग। किसी भी संख्या को स्टैक किया जा सकता है (जैसे !:t:r:p
)।
h
- बेस फाइलनाम तक लाइनt
- केवल आधार फ़ाइल नामr
- फ़ाइल नाम एक्सटेंशन तक लाइनe
- केवल फ़ाइल नाम एक्सटेंशनs/search/replacement
- के search
साथ पहली घटना को बदलेंreplacement
gs/search/replacement
- के search
साथ सभी घटनाओं को बदलेंreplacement
!-#
लोगों का उपयोग नहीं करता । मैं प्रयोग करते हैं !string
यकीन है कि मैं सही काम चल रहा हूँ बनाने के लिए पिछले आदेश है कि तार के साथ शुरू होता है चलाने के लिए, लेकिन मैं आम तौर पर यह पहला टैब-पूरा (zsh)
!N
कमांड चलाएगा ..." एक विवरण बहुत संकीर्ण है; वास्तव में, !N
कमांड द्वारा प्रतिस्थापित किया जाएगा ...; और इतने पर जवाब में सभी विवरण के लिए। अधिक सही और बहुत अधिक उपयोगी संभावनाएं खोलना! जैसे, उल्लेख किया sudo !!
।
bash
; Emacs में, इनपुट कमांड्स और वैल्यूज़ (Mx या अन्य रीड वैल्यूज़ के लिए) के इतिहास के माध्यम से ब्राउज़ करने के लिए, इसके बजाय मेटा-R का उपयोग करता है (मेटा-R का उपयोग eshell
Emacs में भी किया जाता है)। इसलिए मैं अक्सर उन्हें गड़बड़ कर देता हूं।
बैश - पूर्ववर्ती लाइन के अंतिम पैरामीटर डालें
alt- . सबसे उपयोगी कुंजी संयोजन, इसे आज़माएं और देखें, किसी कारण से इस बारे में कोई नहीं जानता है।
पुराने अंतिम मापदंडों को चुनने के लिए इसे बार-बार दबाएं।
जब आप कुछ समय पहले उपयोग किए गए तर्क / फ़ाइल के लिए कुछ और करना चाहते हैं तो बहुत अच्छा है।
alt
- .
यह पिछले कमांड पर जाएगा और अंतिम तर्क को इससे खींच लेगा। तो अगर आप तीन आदेशों पहले से अंतिम तर्क चाहते हैं, बस मारा alt
- .
तीन बार।
yank-last-arg
रीडलाइन कमांड के लिए डिफ़ॉल्ट कुंजी बाइंडिंग है , इसलिए इसे केवल BASH या ZSH के साथ रीडलाइन से जुड़े किसी भी प्रोग्राम के साथ काम करना चाहिए।
मेरी पसंदीदा है
man 7 ascii
सरल और बहुत उपयोगी है।
Oct Dec Hex Char Oct Dec Hex Char
────────────────────────────────────────────────────────────────────────
000 0 00 NUL '\0' (null character) 100 64 40 @
001 1 01 SOH (start of heading) 101 65 41 A
002 2 02 STX (start of text) 102 66 42 B
003 3 03 ETX (end of text) 103 67 43 C
004 4 04 EOT (end of transmission) 104 68 44 D
005 5 05 ENQ (enquiry) 105 69 45 E
006 6 06 ACK (acknowledge) 106 70 46 F
007 7 07 BEL '\a' (bell) 107 71 47 G
010 8 08 BS '\b' (backspace) 110 72 48 H
011 9 09 HT '\t' (horizontal tab) 111 73 49 I
012 10 0A LF '\n' (new line) 112 74 4A J
013 11 0B VT '\v' (vertical tab) 113 75 4B K
014 12 0C FF '\f' (form feed) 114 76 4C L
015 13 0D CR '\r' (carriage ret) 115 77 4D M
016 14 0E SO (shift out) 116 78 4E N
017 15 0F SI (shift in) 117 79 4F O
020 16 10 DLE (data link escape) 120 80 50 P
021 17 11 DC1 (device control 1) 121 81 51 Q
022 18 12 DC2 (device control 2) 122 82 52 R
023 19 13 DC3 (device control 3) 123 83 53 S
024 20 14 DC4 (device control 4) 124 84 54 T
025 21 15 NAK (negative ack.) 125 85 55 U
026 22 16 SYN (synchronous idle) 126 86 56 V
027 23 17 ETB (end of trans. blk) 127 87 57 W
030 24 18 CAN (cancel) 130 88 58 X
031 25 19 EM (end of medium) 131 89 59 Y
032 26 1A SUB (substitute) 132 90 5A Z
033 27 1B ESC (escape) 133 91 5B [
034 28 1C FS (file separator) 134 92 5C \ '\\'
035 29 1D GS (group separator) 135 93 5D ]
036 30 1E RS (record separator) 136 94 5E ^
037 31 1F US (unit separator) 137 95 5F _
040 32 20 SPACE 140 96 60 `
041 33 21 ! 141 97 61 a
042 34 22 " 142 98 62 b
043 35 23 # 143 99 63 c
044 36 24 $ 144 100 64 d
045 37 25 % 145 101 65 e
046 38 26 & 146 102 66 f
047 39 27 ' 147 103 67 g
050 40 28 ( 150 104 68 h
051 41 29 ) 151 105 69 i
052 42 2A * 152 106 6A j
053 43 2B + 153 107 6B k
054 44 2C , 154 108 6C l
055 45 2D - 155 109 6D m
056 46 2E . 156 110 6E n
057 47 2F / 157 111 6F o
060 48 30 0 160 112 70 p
061 49 31 1 161 113 71 q
062 50 32 2 162 114 72 r
063 51 33 3 163 115 73 s
064 52 34 4 164 116 74 t
065 53 35 5 165 117 75 u
066 54 36 6 166 118 76 v
067 55 37 7 167 119 77 w
070 56 38 8 170 120 78 x
071 57 39 9 171 121 79 y
072 58 3A : 172 122 7A z
073 59 3B ; 173 123 7B {
074 60 3C < 174 124 7C |
075 61 3D = 175 125 7D }
076 62 3E > 176 126 7E ~
077 63 3F ? 177 127 7F DEL
इस वेबसाइट commandlinefu.com पर एक नजर है ।
आप पीटरिस क्रुमिंस के इन चार लेखों पर उनके ब्लॉग पर भी नज़र डाल सकते हैं
ascii
कार्यक्रम भी उपयोगी है। तालिका को प्रिंट करने के अलावा, यह आपको एक या अधिक व्यक्तिगत वर्णों के लिए क्वेरी करने देता है।
यकीन नहीं होता कि यह "चाल" के रूप में गिना जाता है, लेकिन लोग मानक रीडलाइन हॉटकीज़ से बहुत अनजान हैं। गोले में विशेष उपयोग की:
Ctrl+L
FormFeed ascii चरित्र से मेल खाती है। यह आम तौर पर एक स्क्रीन विंडो (जैसे vim, less, mc, आदि) के साथ पाठ अनुप्रयोगों में स्क्रीन को फिर से डिज़ाइन करेगा। अच्छा है अगर स्क्रीन दूसरे प्रोग्राम के कुछ आउटपुट से "प्रदूषित" हुई है।
Ctrl+W
एक शब्द को पीछे की ओर काटना, एक शब्द Alt+F
को आगे बढ़ाने के Alt+B
लिए , एक शब्द को एक पंक्ति में पीछे जाना। मुझे पसंद है Ctrl+Y
और Shift+Insert
क्योंकि आपके पास दो कॉपी लाइनें हो सकती हैं। एक के साथ Ctrl+U
(इसे पेस्ट करें Ctrl+Y
) और उसी समय आप दूसरे शब्द (लाइन का चयन करें) के साथ पेस्ट ( Shift+Insert
) कर सकते हैं।
CTRL+ Rपहले निष्पादित कमांड (~ / .bash_history की सामग्री) को खोजने / सक्रिय करने के लिए BASH में।
यह अक्सर बेहद मददगार होता है। इस उपनाम को चलाने से पोर्ट 8000 पर HTTP (अनुक्रमित) पर PWD की सेवा होगी:
alias webserver="python -m SimpleHTTPServer"
और क्योंकि मैं हर समय दौड़ता हूं, और बाहर घूमता हूं और जल्दी से टाइप करता हूं, ये उपनाम शायद मेरा सबसे अधिक इस्तेमाल किया जाता है (गंभीरता से):
alias maek=make
alias mkae=make
alias meak=make
alias amka=make
alias akme=make
और शायद BASH का मेरा सबसे अक्सर इस्तेमाल किया जाने वाला टुकड़ा एक साधारण स्क्रिप्ट है जिसे मैं अपलोड कहता हूं। मैं इसका उपयोग अपने Linode को किसी भी प्रकार की सामग्री को धुंधला करने के लिए करता हूं, और यह परिणामी HTTP URL को मेरे क्लिपबोर्ड (मध्य क्लिक) में कॉपी करता है। IRC में लोगों को सामान चिपकाने के लिए बहुत उपयोगी:
scp -r $* $user@$host:public_html && {
URL="http://$host/~$user/$(basename $1)"
echo "$URL"
xselection -replace PRIMARY "$URL"
}
बस एक जेाड़ा। मैं बहुत बाद में पोस्ट कर सकता हूं, काम पर वापस जाना चाहिए!
alias mk=make
टाइप करने के लिए तेज़ और गलत होने की संभावना कम। या एक हॉटकी का उपयोग करके अपने संपादक से संकलन करें ...
alias m=make
, या यहाँ तक m=make -j6
या इसी तरह - सिवाय मैं पहले से ही उपयोग करें alias m=mutt
☺
सुंदर बुनियादी, लेकिन लोगों को पता नहीं लगता है, आपको पिछले dir में लौटाता है:
cd -
cd..
डॉस से मेरी मांसपेशियों की स्मृति में अंतर्ग्रहण होता है ...
cd
(कोई तर्क के साथ) जो आपको अपने घर निर्देशिका में ले जाता है।
ब्रेस विस्तार एक तंत्र है जिसके द्वारा मनमाने तार उत्पन्न किए जा सकते हैं।
यह आपको थकाऊ लाइनों को बदलने की अनुमति देता है जैसे:
mv loong/and/complex/file/name loong/and/complex/file/name.bacukup
एक छोटे उदाहरण के साथ
mv loong/and/complex/file/name{,backup}
कुछ अन्य उपयोग
# to display the diff between /etc/rc.conf and /etc/rc.conf.pacsave
diff /etc/rc.conf{,.pacsave}
# to list files in both /usr/share and /usr/local/share
ls /usr/{,local}/share
अंकगणित विस्तार :
अंकगणित विस्तार एक अंकगणितीय अभिव्यक्ति के मूल्यांकन और परिणाम के प्रतिस्थापन की अनुमति देता है। अंकगणितीय विस्तार के लिए प्रारूप है:
$((expression))
अभिव्यक्ति को ऐसे माना जाता है जैसे कि यह दोहरे उद्धरण चिह्नों के भीतर है, लेकिन कोष्ठकों के अंदर एक दोहरे उद्धरण का विशेष रूप से व्यवहार नहीं किया जाता है। अभिव्यक्ति में सभी टोकन पैरामीटर विस्तार, स्ट्रिंग विस्तार, कमांड प्रतिस्थापन और उद्धरण हटाने से गुजरते हैं। अंकगणित विस्तार को नेस्टेड किया जा सकता है।
$ a=1
$ b=2
$ echo $(( a+(b*2) ))
5
foo[123]
कि में विस्तार होगा foo1 foo2 foo3
, लेकिन वे उस मामले में काम करने के लिए फ़ाइल नाम होने की जरूरत है
यह आमतौर पर मेरी स्टार्टअप स्क्रिप्ट (.bashrc, .profile, जो भी हो) में होता है
shopt
अच्छाई, टिप्पणियों की जाँच करें:
shopt -s cdspell # try to correct typos in path
shopt -s dotglob # include dotfiles in path expansion
shopt -s hostcomplete # try to autocomplete hostnames
एक उपनाम जो कीस्ट्रोक्स को बचाता है:
mkdir
और cd
इसमें:
mkcd () { mkdir -p "$@" && cd "$@"; }
और अंतिम लेकिन कम से कम, मैंने टार सिंटैक्स को याद रखने पर छोड़ दिया है, इसलिए:
extract () {
if [ -f $1 ] ; then
case $1 in
*.tar.bz2) tar xjf $1 ;;
*.tar.gz) tar xzf $1 ;;
*.bz2) bunzip2 $1 ;;
*.rar) rar x $1 ;;
*.gz) gunzip $1 ;;
*.tar) tar xf $1 ;;
*.tbz2) tar xjf $1 ;;
*.tgz) tar xzf $1 ;;
*.zip) unzip $1 ;;
*.Z) uncompress $1 ;;
*) echo "'$1' cannot be extracted via extract()" ;;
esac
else
echo "'$1' is not a valid file"
fi
}
mkcd
जिसे मैं नाम देता हूं md
। हालाँकि cd को तर्क के रूप में "$ @" का उपयोग करने का कोई मतलब नहीं है क्योंकि आप एक से अधिक एकल निर्देशिका के लिए सीडी नहीं कर सकते हैं। "$ @" mkdir के लिए काम करेगा, लेकिन तब आप mkdir और cd के लिए अलग-अलग तर्क दे रहे हैं, इसलिए मैं सुझाव md () { mkdir -p "$1"; cd "$1" }
दो बाश कार्य जो मुझे कई महत्वपूर्ण स्ट्रोक से बचाते हैं।
हर सफल सीडी के बाद स्वचालित रूप से एक ls करें:
function cd {
builtin cd "$@" && ls
}
एन स्तर ऊपर जाएं:
# Usage .. [n]
function .. (){
local arg=${1:-1};
local dir=""
while [ $arg -gt 0 ]; do
dir="../$dir"
arg=$(($arg - 1));
done
cd $dir #>&/dev/null
}
builtin foo
एक समारोह परिभाषित होने के आसपास प्राप्त करने के लिए कभी नहीं कर सकते थे cd
; मैं chdir
अपने कार्यों में उपयोग कर रहा हूं। हैंडी
cd() { builtin cd -- "$@" && { [ "$PS1" = "" ] || ls -hrt --color; }; }
चूंकि मैं आमतौर पर खोज करने से पहले कमांड लाइन में आधे रास्ते पर हूं (सीटीआरएल-आर बैश में) मेरे पास .brc में निम्नलिखित है।
bind '"\e[A"':history-search-backward
bind '"\e[B"':history-search-forward
इसका मतलब यह है कि अगर मैं cd टाइप करता हूं तो ऊपर / नीचे दबाएं मैं उन सभी विकल्पों को देख सकता हूं जिनके लिए मेरे पास cd'd है। मूल रूप से मैं अक्सर इस्तेमाल किए गए डायर के लिए इसका उपयोग करता हूं। "Cd w" की तरह और मैं उन सभी कार्यक्षेत्रों से गुजर रहा हूं, जिनका मैं बहुत उपयोग करता हूं।
एक चीज जो मुझे बहुत समय बचाती है वह है पुशड / पॉपड कमांड। ये लोग आपको निर्देशिकाओं का एक ढेर बनाने और टाइपिंग को कम करने देते हैं:
/foobar/ > pushd /src/whatever/foo/test
/foobar/src/whatever/foo/test > make run
/foobar/src/whatever/foo/test > popd
/foobar/ > make
u
और o
यहाँ के लिए खड़े हो?
setopt autopushd
और सभी निर्देशिका परिवर्तन स्वचालित रूप से धक्का देंगे
screen
आदेश । जब आप वापस आते हैं तो यह मूल रूप से आपके कमांड लाइन सत्र को बचाता है। यह विंडो मैनेजर की तरह टर्मिनल मैनेजर की तरह है। इस तरह, एक ही टर्मिनल सत्र में, आपके पास कई वर्चुअल टर्मिनल हो सकते हैं। यह बहुत अच्छा है।
यदि कोई उपयोग करता है screen
, तो यह शेल फ़ंक्शन (इसे डालें .bashrc
) अत्यंत उपयोगी है:
function scr {
if screen -ls | grep -q Main; then
# reattach to Main:
screen -xr Main
else
# name session "Main":
screen -S Main
fi
}
टाइप करने पर scr
, यह जांच करेगा कि आपका मुख्य सत्र मौजूद है या नहीं। अन्यथा यह इसे बनाएगा।
यदि आपको विशेष रूप से लंबी कमांड लाइन को बैश में संपादित करने की आवश्यकता है
^X^E (Ctrl-X Ctrl-E)
इसे संपादक ($ EDITOR) में खोलेंगे।
Zsh में आप इसे .zshrc में जोड़कर समान व्यवहार प्राप्त कर सकते हैं:
autoload edit-command-line
zle -N edit-command-line
bindkey '^X^e' edit-command-line
यदि आप एक तेज टाइपिस्ट हैं, तो ये काम आते हैं:
alias grpe='grep --color=tty'
alias gpre='grep --color=tty'
alias rgep='grep --color=tty'
alias gerp='grep --color=tty'
यह मैक्रो आपको आउटपुट के एक कॉलम के योगों की गणना करने में मदद करता है: फ़ाइल आकार, बाइट्स, पैकेट, आपको बस इतना करना होगा कि आप उस कॉलम को निर्दिष्ट करें जिसे आप जोड़ना चाहते हैं:
total ()
{
if [ x$1 = x ]; then set `echo 1`; fi
awk "{total += \$$1} END {print total}"
}
आप इसका उपयोग इस तरह से करते हैं, उदाहरण के लिए, बिना किसी तर्क के, यह पहले स्तंभ के कुल को जोड़ता है:
du | total
यदि आप तर्क प्रदान करते हैं, तो यह उस कॉलम को सम्मिलित करेगा, उदाहरण के लिए, यह आपको सभी C # फ़ाइलों द्वारा / tmp में उपयोग की जाने वाली बाइट्स की कुल संख्या देता है:
ls -l /tmp/*cs | total 5
कभी-कभी आपका कंसोल गड़बड़ हो जाता है क्योंकि आपने गलती से एक बाइनरी फ़ाइल देखी (उदाहरण के लिए बिल्ली / बिन / एलएस), आप इस शेल फ़ंक्शन के साथ टर्मिनल को पुनर्स्थापित कर सकते हैं:
restaura ()
{
perl -e 'print "\e)B";'
}
मुझे फ़ाइलों के वर्ग को अलग करने के लिए वर्णों का उपयोग करने के लिए मेरा एलएस पसंद है, और मेरे संपादक द्वारा उत्पन्न बैकअप फ़ाइलों को छिपाने के लिए भी (बैकअप फ़ाइलें ~ चरित्र के साथ समाप्त)
alias ls='ls -FB'
s/fast/sloppy/
reset
आप जहां इस्तेमाल करते हैं मैं वहीं करता हूं restaura
।
alias s='sudo'
alias r='rake' # i'm a ruby developer
alias ..='cd ..' # although with autocd feature for zsh this comes packed.
मेरे पसंदीदा में से एक जब मैं भूल जाता हूं s
:
$ s !! # last command with super user priviledges
bindkey -s '\e[12~' "sudo !!\n"
उस कमांड को चलाने के लिए (इस मामले में) F2 को बांधने जैसा कुछ कर सकते हैं । मेरे पास वह बंधन है, इसलिए जब मैं कुछ चलाता हूं और "आप भूल गए 'सुडो', मूर्ख" त्रुटि संदेश देखते हैं, तो मैं सिर्फ F2 को झुंझलाहट में दबा सकता हूं
यदि कोई कमांड स्टड इनपुट लेता है, तो आप फ़ाइल से इनपुट पढ़ सकते हैं <filename
। यह कमांड में कहीं भी दिखाई दे सकता है, इसलिए ये लाइनें समतुल्य हैं:
cat filename
cat <filename
<filename cat
यह विशेष रूप से grep के लिए उपयोगी है, क्योंकि यह आपको लाइन के अंत में अभिव्यक्ति देने की अनुमति देता है, इसलिए आप Upफ़ाइल नाम को प्राप्त करने के लिए बाएं स्क्रॉल करने की आवश्यकता के बिना इसे जल्दी से grep कमांड को संशोधित कर सकते हैं :
<filename grep 'expression'
<input foo | bar | baz >output
, तो यह काम नहीं करता है यदि आप कुछ शेल लूपिंग आदिम मिश्रण करने की कोशिश करते हैं जैसे कि while
या for
बीच में। इसलिए मैंने हार मान ली और बस सम्मेलन के अनुसार इसे अंत में रखा।
आप CDPATH
निर्देशिका के बराबर सेट अप करने के लिए उपयोग कर सकते हैं PATH
; यदि आप करने की कोशिश cd foo
और कोई foo
मौजूदा निर्देशिका में, खोल में निर्देशिका में से प्रत्येक की जाँच करेगा CDPATH
की तलाश में foo
उन में है, और पहले एक यह पाता है करने के लिए स्विच:
export CDPATH="/usr"
cd bin # switches to 'bin' if there is one in the current directory, or /usr/bin otherwise
vi `which scriptname`
जब आप नहीं जानते कि कुछ कहाँ रहता है, और आपको कोई परवाह नहीं है।
which
स्वचालित रूप से आह्वान करने के लिए , इसलिएvi =scriptname
$(scriptname)
एम्परसेंड । यह आपकी कमांड को पृष्ठभूमि में रखता है, जिससे आप टाइपिंग जारी रख सकते हैं।
$> sudo updatedb &
साथ काम करना, और थोड़ी देर बाद आप देखें:
[1] 17403
और आपकी प्रक्रिया पूरी हो गई है! उन चीज़ों के लिए बढ़िया जहाँ आपको उन्हें समाप्त करने के लिए प्रतीक्षा करने की आवश्यकता नहीं है।
&!
नौकरी की पृष्ठभूमि के लिए आवेदन करें और इसे शेल से हटा दें!
bash
।
nohup
पूरा करने के साथ कमांड तैयार करना ।
टैब पूरा करना । अगर आपको हर रास्ते के सभी पात्रों को लिखना पड़े तो यह कितना बुरा होगा?
rm -fr /
। तो हाँ, टैब पूरा होने के लिए बहुत महत्वपूर्ण है ...
ls /usr/lib/game-d*/rott*
rm -rf /
अधिकांश लिनक्स सिस्टम में अक्षम नहीं है?
अंतिम घुड़सवार डिवाइस:
mount /media/whatever
...
u!mo
!mo
अंतिम कमांड तक फैलता है, जिसकी शुरुआत mo
(कम से कम बाश में) हुई थी। कभी-कभी कोई mv
बीच में आता है, इसलिए u!m
अक्सर काम नहीं करेगा।
मेरे पास मेरे .bashrc में है
#shortcut for CTRL+C and CTRL+V
alias c-c='xclip -sel clip'
alias c-v='xclip -o -sel clip'
function find-all() {
python -c "import re
import sys
for i in re.findall('$1', sys.stdin.read()):
if type(i) == type(''):
print i
else:
print i[0]"
}
और जब मेरे पास क्लिपबोर्ड में html स्रोत कोड है और मैं उपयोग किए जाने वाले सभी लिंक ढूंढना चाहता हूं
c-v | find-all 'href="([^"]*)"' | c-c
और मेरे पास क्लिपबोर्ड में सभी यूआरएल हैं
मेरा भी यह फंक्शन है
function lsq(){
ls -lh $@ | tr -s ' ' | cut -d' ' -f5,8
}
जो प्रदर्शन आकार (मानव पठनीय) और फ़ाइल नाम।
alias temp='cat /proc/acpi/thermal_zone/THRM/temperature'
यह उपनाम शो टेंपरेचर के लिए है
function separate() {
python -c "import sys,re; print '$1'.join(re.split('\s*', sys.stdin.read().strip()))";
}
इस फ़ंक्शन के साथ मैं उत्पाद या तर्कों की गणना कर सकता हूं।
alias sum='separate + | bc'
alias product='separate * | bc'
function split-join() {
python -c "import sys,re; print '$2'.join(re.split('$1', sys.stdin.read().strip()))";
}
यह उपयोगी फ़ंक्शन है जो रेगेक्स द्वारा अलग किए गए मानक इनपुट को विभाजित करता है और फिर परिणाम में शामिल होता है।
function factorial() {
seq -s* $1 | bc
}
तथ्यात्मक कार्य
function wiki() { dig +short txt $1.wp.dg.cx; }
यह फ़ंक्शन DNS पर विकि पाठ प्रदर्शित करता है
मेरे पास तीन रंग फंक भी हैं
function blue() {
echo -e "\x1b[34m\x1b[1m"$@"\x1b[0m";
}
function green() {
echo -e "\x1b[32m\x1b[1m"$@"\x1b[0m";
}
function red() {
echo -e "\x1b[31m\x1b[1m"$@"\x1b[0m";
}
function md5check() {
test `md5sum $2 | cut -d' ' -f1` = "$1" && green [OK] || red [FAIL]
}
यह फ़ंक्शन फ़ाइल md5 हैश को मान्य करता है।
यह किसी दिए गए कोड के लिए त्रुटि संदेश दिखाएगा
function strerror() { python -c "import os; print os.strerror($1)"; }
आप सभी संदेशों को प्रिंट कर सकते हैं
alias all-errors='for i in `seq 131`; do echo -n "$i: "; strerror $i; done'
एक और उपयोगी ZSH चाल:
एक फ़ाइल के रूप में एक कमांड के आउटपुट का इलाज करें:
emacs =(hg cat -r 100 somefile)
यह सिंटैक्स-हाइलाइटेड देखने के लिए emacs में एक मर्क्यूरियल-ट्रैक की गई फ़ाइल का एक पुराना संस्करण खोलता है। कि बिना, मैं के साथ चारों ओर गंदगी करना होगा hg revert
, hg archive
या स्पष्टतया भेजhg cat
एक अस्थायी फ़ाइल के लिए उत्पादन।
बेशक, यह किसी भी प्रोग्राम के साथ काम करता है जो फाइलें खोलता है, और कोई भी प्रोग्राम जो मानक आउटपुट पर प्रिंट करता है।
ZSH- विशिष्ट विशेषता प्रत्यय उपनाम है, alias
जिसे -s
ध्वज दिया गया है :
alias -s ext=program
यदि किसी दिए गए एक्सटेंशन में प्रत्यय उपनाम है, तो आप उस एक्सटेंशन के साथ एक फ़ाइल को सीधे निष्पादित कर सकते हैं, और ZSH दिए गए प्रोग्राम को लॉन्च करेंगे और फ़ाइलनाम को एक तर्क के रूप में पास करेंगे। इसलिए यदि उपरोक्त उपनाम प्रभाव में है, तो ये रेखाएं समतुल्य हैं:
/path/to/foo.ext
program /path/to/foo.ext
मेरी सर्वकालिक पसंदीदा ZSH सुविधाओं में से एक का नाम निर्देशिका है। आप किसी दिए गए नाम के साथ एक चर का निर्यात कर सकते हैं, जो एक निश्चित मार्ग की ओर इशारा करता है:
export foo=/usr/bin
अब आप ~foo
एक कमांड में इसका उपयोग कर सकते हैं /usr/bin
:
cd ~foo
~foo/ls
cat ~foo/filename
इस प्रश्न को देखें ।
जब आप दौड़ते हैं ps ax | grep string
:
[steve@sage-arch ~]$ ps ax | grep 'openbox'
3363 ? Ss 0:00 /usr/bin/openbox
3382 ? Ss 0:00 /usr/bin/ssh-agent -- /usr/bin/openbox-session
3386 ? S 0:00 /bin/sh /usr/bin/openbox-session
3388 ? S 0:00 /bin/sh /usr/bin/openbox-session
3389 ? S 0:00 /bin/sh /usr/bin/openbox-session
3390 ? S 0:00 /bin/sh /usr/bin/openbox-session
5100 pts/0 S+ 0:00 grep openbox
अंतिम पंक्ति में सम्मिलित हैgrep
थोड़ा सा aoying
आप इसे चलाकर खुद को इससे छुटकारा दिला सकते हैं ps ax | grep '[s]tring'
:
[steve@sage-arch ~]$ ps ax | grep '[o]penbox'
3363 ? Ss 0:00 /usr/bin/openbox
3382 ? Ss 0:00 /usr/bin/ssh-agent -- /usr/bin/openbox-session
3386 ? S 0:00 /bin/sh /usr/bin/openbox-session
3388 ? S 0:00 /bin/sh /usr/bin/openbox-session
3389 ? S 0:00 /bin/sh /usr/bin/openbox-session
3390 ? S 0:00 /bin/sh /usr/bin/openbox-session
अद्यतन : या बस चलाते हैंpgrep string
'[o]penbox'
)। कोष्ठक एक ग्लोब की तरह काम करेगा, इसलिए यदि आपकी निर्देशिका में ओपनबॉक्स है (कहते हैं कि आप में हैं /usr/bin
) बस ओपनबॉक्स का उपयोग करेगा, जिससे ग्रीप ट्रिक को रोका जा सकेगा।
कुछ भी नहीं के :
रूप में आदेश
while :; do :; done
छोरों के साथ संयोजन में ब्रेस विस्तार:
for c in {1..3}; do :; done
!
ऑपरेटर और शॉर्ट सर्कुलेटिंग ऑपरेटर ||
और&&
[ -d /tmp/dir ] || mkdir /tmp/dir
if ! ping 34.41.34.1; then :; fi
पॉप / पुश के बजाय उप गोले का उपयोग करना (स्क्रिप्ट में काम आता है)
~$ ( cd /tmp; echo $PWD )
/tmp
~$
किस- किस का कमांड हैtype
~$ type type
type is a shell builtin
~$ type ls
ls is aliased to `ls --color=auto'
~$ f(){ :; }
~$ type f
f is a function
f ()
{
:
}
भी बहुत अच्छा: यहाँ-तार
~$ cat <<<"here $PWD"
here /home/yourname
~$
और मेरा पसंदीदा: आदेशों की सूची पर पुनर्निर्देशन
{ w; ps; ls /tmp; } 2>/dev/null |less
मुझे अपने पीएस 1 में जितना हो सकता है, उतना ही चाक करना पसंद है। याद रखने योग्य कुछ उपयोगी बातें:
\e[s
और \e[u
क्रमशः कर्सर की स्थिति को बचाने और सहेजना। मैं इसका उपयोग स्क्रीन के शीर्ष पर एक 'इंफो-बार' बनाने के लिए करता हूं, एक दो लाइन लंबी, जो अधिक सामान फिट कर सकती है। उदाहरण:
PS1='\[\e[s\e[7m\e[1;1H\]\w\n\t \j / \! / \#\[\e[u\e[0m\e[33;1m\][\u@\h \[\e[34m\]\W]\[\e[0m\]\$ '
के साथ मिला लें alias clear='echo -e "\e[2J\n"'
। कोशिश करके देखो!
इसके अलावा, PROMPT_COMMAND
चर हर बार PS1 से पहले निष्पादित करने के लिए एक कमांड को परिभाषित करता है।
एक और एक bg
आदेश है। यदि आप &
एक कमांड के अंत में रखना भूल जाते हैं , तो बस दबाएं ^Zऔर टाइप करें bg
, और यह पृष्ठभूमि में चलता है।
bg
, जब मेरे पास पृष्ठभूमि में एक कार्यक्रम चल रहा है और गलती से प्रेस हो जाता है तो fg
मुझे नहीं पता कि इसे कैसे पीछे धकेलना है: D
PS1
इसलिए मैंने अपनी स्क्रीन के नीचे की लाइन में अपना अधिकांश सामान रखा ...