Jawaban:
Ini agak memperluas !!
trik yang disebutkan dalam jawaban ini . Sebenarnya ada banyak perintah terkait sejarah yang cenderung dilupakan (orang cenderung menusuk Up100 kali alih-alih mencari perintah yang mereka tahu mereka ketikkan).
history
perintah akan menampilkan daftar baru menjalankan perintah dengan acara penanda ke kiri!N
akan mengganti perintah yang terkait dengan penunjuk acara N
!-N
akan menggantikan perintah terbaru N
th ; mis. !-1
akan menggantikan perintah terbaru, !-2
yang kedua terbaru, dll.!!
adalah singkatan untuk !-1
, dengan cepat mengganti perintah terakhir!string
akan mengganti perintah terbaru yang dimulai dengan string
!?string?
akan menggantikan perintah terbaru yang berisi string
Penunjuk kata dapat ditambahkan ke !
perintah sejarah untuk mengubah hasilnya. Tanda titik dua memisahkan penunjuk acara dan kata, mis !!:0
. Penunjuk acara !!
dapat disingkat menjadi hanya !
ketika menggunakan penunjuk kata, sehingga !!:0
setara dengan !:0
.
!:0
akan mendapatkan perintah yang dieksekusi!:1
akan mendapatkan argumen pertama (dan !:2
yang kedua, dll.)!:2-3
akan mendapatkan argumen kedua dan ketiga!:^
adalah cara lain untuk mendapatkan argumen pertama. !:$
akan mendapatkan yang terakhir!:*
akan mendapatkan semua argumen (tetapi bukan perintah)Pengubah juga dapat ditambahkan ke !
perintah sejarah, masing-masing diawali oleh tanda titik dua. Nomor berapa pun dapat ditumpuk (misalnya !:t:r:p
).
h
- Berbaris ke nama file dasart
- Hanya nama file dasarnyar
- Berbaris ke ekstensi nama filee
- Hanya ekstensi nama files/search/replacement
- Ganti kemunculan pertama search
denganreplacement
gs/search/replacement
- Ganti semua kemunculan search
denganreplacement
!-#
yang baik. Saya memang menggunakan !string
untuk menjalankan perintah terakhir yang dimulai dengan string, tetapi saya biasanya tab-lengkapi dulu (zsh) untuk memastikan saya menjalankan hal yang benar
!N
akan menjalankan perintah ..." adalah deskripsi yang terlalu sempit; sebenarnya, !N
akan diganti oleh perintah ...; dan seterusnya untuk semua deskripsi dalam jawaban. Lebih tepat dan membuka kemungkinan lebih bermanfaat! Misalnya, yang disebutkan sudo !!
.
bash
; di Emacs, untuk menelusuri sejarah perintah dan nilai input (untuk Mx atau nilai baca lainnya) seseorang menggunakan Meta-R sebagai gantinya (Meta-R juga digunakan di eshell
dalam Emacs). Jadi saya sering mengacaukannya.
bash - masukkan parameter akhir baris sebelumnya
alt- . kombinasi tombol paling berguna yang pernah ada, coba dan lihat, untuk beberapa alasan tidak ada yang tahu tentang yang ini.
tekan lagi dan lagi untuk memilih parameter terakhir yang lebih lama.
hebat ketika Anda ingin melakukan sesuatu yang lebih pada argumen / file yang Anda gunakan beberapa saat yang lalu.
alt
- .
itu akan pergi ke perintah sebelumnya dan menarik argumen terakhir dari itu. Jadi jika Anda ingin argumen terakhir dari tiga perintah yang lalu, tekan saja alt
- .
tiga kali.
yank-last-arg
perintah readline, jadi itu harus bekerja dengan program apa pun yang terhubung dengan readline, bukan hanya BASH atau ZSH.
Favorit saya adalah
man 7 ascii
Sederhana dan sangat bermanfaat.
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
Lihatlah situs web ini commandlinefu.com .
Anda juga dapat melihat empat artikel ini oleh Peteris Krumins di blog-nya
ascii
Program ini juga berguna. Selain mencetak tabel, ini memungkinkan Anda meminta satu atau lebih karakter individual.
Tidak yakin apakah ini dianggap sebagai "trik", tetapi orang-orang tampaknya tidak menyadari hotkey readline standar. Penggunaan khusus dalam kerang:
Ctrl+L
sesuai dengan karakter ascii FormFeed. Biasanya akan menggambar ulang layar dalam aplikasi teks dengan jendela layar (mis. Vim, less, mc, dll). Bagus jika layar telah "tercemar" oleh beberapa output dari program lain.
Ctrl+W
untuk memotong satu kata ke belakang, Alt+F
untuk maju satu kata, Alt+B
untuk pergi satu kata ke belakang dalam satu baris. Saya suka Ctrl+Y
dan Shift+Insert
karena Anda dapat memiliki dua baris yang disalin. Satu dengan Ctrl+U
(tempel dengan Ctrl+Y
) dan pada saat yang sama Anda dapat menyalin kata lain (pilih baris) tempel dengan ( Shift+Insert
).
CTRL+ Rdi BASH untuk mencari / mengaktifkan perintah yang sebelumnya dieksekusi (isi ~ / .bash_history).
Ini seringkali sangat membantu. Menjalankan alias ini akan melayani PWD di atas HTTP (diindeks) pada port 8000:
alias webserver="python -m SimpleHTTPServer"
Dan karena saya menjalankan make sepanjang waktu, dan mengetik dan mengetik terlalu cepat, alias ini mungkin yang paling sering saya gunakan (serius):
alias maek=make
alias mkae=make
alias meak=make
alias amka=make
alias akme=make
Dan mungkin BASH saya yang paling sering digunakan adalah script sederhana yang saya sebut unggah. Saya menggunakannya untuk mencampur segala jenis konten ke Linode saya, dan menyalin URL HTTP yang dihasilkan ke clipboard saya (klik tengah). Sangat berguna untuk menempelkan hal-hal kepada orang-orang di IRC:
scp -r $* $user@$host:public_html && {
URL="http://$host/~$user/$(basename $1)"
echo "$URL"
xselection -replace PRIMARY "$URL"
}
Hanya pasangan. Saya dapat memposting lebih banyak lagi nanti, harus kembali bekerja!
alias mk=make
Lebih cepat mengetik dan kecil kemungkinannya salah. Atau kompilasi dari editor Anda menggunakan hotkey ...
alias m=make
, atau bahkan m=make -j6
atau serupa - kecuali saya sudah menggunakan alias m=mutt
☺
Cukup mendasar, tetapi orang-orang sepertinya tidak tahu, mengembalikan Anda ke dir sebelumnya:
cd -
cd..
dari DOS sudah tertanam dalam memori otot saya ...
cd
(tanpa argumen) yang akan membawa Anda ke direktori home Anda.
Perluasan brace adalah mekanisme dimana string sewenang-wenang dapat dihasilkan.
Ini memungkinkan Anda untuk mengganti garis yang membosankan seperti:
mv loong/and/complex/file/name loong/and/complex/file/name.bacukup
dengan contoh yang lebih pendek
mv loong/and/complex/file/name{,backup}
beberapa kegunaan lain
# 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
Ekspansi Aritmatika :
Ekspansi aritmatika memungkinkan evaluasi ekspresi aritmatika dan penggantian hasilnya. Format untuk ekspansi aritmatika adalah:
$((expression))
Ekspresi diperlakukan seolah-olah itu dalam tanda kutip ganda, tetapi tanda kutip ganda di dalam tanda kurung tidak diperlakukan secara khusus. Semua token dalam ekspresi mengalami ekspansi parameter, ekspansi string, penggantian perintah, dan penghapusan kutipan. Ekspansi aritmatika mungkin bersarang.
$ a=1
$ b=2
$ echo $(( a+(b*2) ))
5
foo[123]
yang akan diperluas ke foo1 foo2 foo3
, tetapi mereka harus nama file untuk bekerja dalam kasus itu
Ini biasanya dalam skrip startup saya (.bashrc, .profile, apa pun)
shopt
Astaga, periksa komentarnya:
shopt -s cdspell # try to correct typos in path
shopt -s dotglob # include dotfiles in path expansion
shopt -s hostcomplete # try to autocomplete hostnames
Alias yang menyimpan penekanan tombol:
mkdir
dan cd
ke dalamnya:
mkcd () { mkdir -p "$@" && cd "$@"; }
Dan last but not least, saya sudah menyerah pada menghafal sintaks tar, jadi:
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
yang saya beri nama id md
. Namun menggunakan "$ @" sebagai argumen untuk cd tidak masuk akal karena Anda tidak dapat melakukan cd ke lebih dari satu direktori. "$ @" akan bekerja untuk mkdir, tetapi kemudian Anda menangani argumen secara berbeda untuk mkdir dan cd, jadi saya lebih suka menyarankanmd () { mkdir -p "$1"; cd "$1" }
Dua fungsi bash yang menyelamatkan saya dari banyak goresan kunci.
Lakukan secara otomatis setelah setiap cd yang berhasil:
function cd {
builtin cd "$@" && ls
}
Naik n level:
# 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
untuk mendapatkan fungsi yang didefinisikan cd
; Saya telah menggunakan chdir
fungsi saya. Handy
cd() { builtin cd -- "$@" && { [ "$PS1" = "" ] || ls -hrt --color; }; }
Karena saya biasanya setengah jalan ke baris perintah sebelum ingin mencari (CTRL-R di bash) saya punya yang berikut di .bashrc saya
bind '"\e[A"':history-search-backward
bind '"\e[B"':history-search-forward
Ini berarti bahwa jika saya mengetik cd maka tekan atas / bawah saya dapat melihat semua opsi yang saya punya cd. Pada dasarnya saya menggunakan ini untuk dirs yang sering digunakan. Seperti "cd w" dan saya akhirnya melalui semua ruang kerja yang saya gunakan banyak.
Satu hal yang menghemat banyak waktu adalah perintah pushd / popd. Orang-orang ini memungkinkan Anda membuat tumpukan direktori dan mengurangi banyak mengetik:
/foobar/ > pushd /src/whatever/foo/test
/foobar/src/whatever/foo/test > make run
/foobar/src/whatever/foo/test > popd
/foobar/ > make
u
dan o
berdiri di sini?
setopt autopushd
dan semua perubahan direktori akan mendorong secara otomatis
The screen
perintah . Ini pada dasarnya menyimpan sesi baris perintah Anda ketika Anda kembali. Ini semacam manajer terminal, seperti manajer jendela. Dengan begitu, dalam satu sesi terminal, Anda dapat memiliki beberapa terminal virtual. Keren sekali.
Jika digunakan screen
, fungsi shell ini ( .bashrc
sangat bermanfaat):
function scr {
if screen -ls | grep -q Main; then
# reattach to Main:
screen -xr Main
else
# name session "Main":
screen -S Main
fi
}
saat mengetik scr
, itu akan memeriksa apakah sesi utama Anda ada dan akan melampirkannya. Kalau tidak, itu akan membuatnya.
Jika Anda perlu mengedit baris perintah yang sangat panjang di bash
^X^E (Ctrl-X Ctrl-E)
akan membukanya di editor ($ EDITOR).
Di zsh Anda bisa mendapatkan perilaku yang sama dengan menambahkan ini ke .zshrc:
autoload edit-command-line
zle -N edit-command-line
bindkey '^X^e' edit-command-line
Jika Anda seorang pengetik cepat, ini berguna:
alias grpe='grep --color=tty'
alias gpre='grep --color=tty'
alias rgep='grep --color=tty'
alias gerp='grep --color=tty'
Makro ini membantu Anda menghitung total kolom output: ukuran file, byte, paket, yang harus Anda lakukan adalah menentukan kolom yang ingin Anda tambahkan:
total ()
{
if [ x$1 = x ]; then set `echo 1`; fi
awk "{total += \$$1} END {print total}"
}
Anda menggunakannya seperti ini misalnya, tanpa argumen, itu menambah total kolom pertama:
du | total
Jika Anda memberikan argumen, itu akan menjumlahkan kolom itu, misalnya, ini memberi Anda jumlah total byte yang digunakan oleh semua file C # di / tmp:
ls -l /tmp/*cs | total 5
Kadang-kadang konsol Anda menjadi kacau karena Anda secara tidak sengaja melihat file biner (cat / bin / ls misalnya), Anda dapat memulihkan terminal dengan fungsi shell ini:
restaura ()
{
perl -e 'print "\e)B";'
}
Saya suka ls saya menggunakan karakter untuk membedakan kelas file, dan juga untuk menyembunyikan file cadangan yang dihasilkan oleh editor saya (file cadangan diakhiri dengan ~ karakter):
alias ls='ls -FB'
s/fast/sloppy/
reset
tempat Anda gunakan restaura
.
alias s='sudo'
alias r='rake' # i'm a ruby developer
alias ..='cd ..' # although with autocd feature for zsh this comes packed.
Salah satu favorit saya ketika saya lupa s
:
$ s !! # last command with super user priviledges
bindkey -s '\e[12~' "sudo !!\n"
mengikat (dalam hal ini) F2 untuk menjalankan perintah itu. Saya memiliki ikatan itu, jadi ketika saya menjalankan sesuatu dan melihat pesan kesalahan "Anda lupa 'sudo', bodoh", saya bisa menusuk F2 dengan kesal
Jika suatu perintah mengambil input stdin, Anda dapat membaca input dari file dengan <filename
. Ini bisa muncul di mana saja di perintah, jadi baris ini setara:
cat filename
cat <filename
<filename cat
Ini sangat berguna untuk grep, karena memungkinkan Anda untuk menempatkan ekspresi di akhir baris, sehingga Anda dapat dengan cepat memodifikasi perintah grep dengan memukul Up, tanpa perlu menggulir ke kiri untuk melewati nama file:
<filename grep 'expression'
<input foo | bar | baz >output
, itu tidak berfungsi jika Anda mencoba mencampur beberapa primitif perulangan shell seperti while
atau for
di tengah. Jadi saya menyerah dan hanya meletakkannya di akhir sesuai konvensi.
Anda dapat menggunakan CDPATH
untuk mengatur direktori yang setara dengan PATH
; jika Anda mencoba cd foo
dan tidak ada foo
dalam direktori saat ini, shell akan memeriksa setiap direktori yang CDPATH
dicari foo
di dalamnya, dan beralih ke yang pertama ditemukan:
export CDPATH="/usr"
cd bin # switches to 'bin' if there is one in the current directory, or /usr/bin otherwise
vi `which scriptname`
Karena ketika Anda tidak tahu di mana sesuatu tinggal, dan Anda juga tidak peduli.
which
secara otomatis, jadivi =scriptname
$(scriptname)
The ampersand . Ini menempatkan perintah Anda di latar belakang, sehingga Anda dapat melanjutkan mengetik.
$> sudo updatedb &
Bekerja bersama, dan setelah beberapa saat Anda melihat:
[1] 17403
Dan proses Anda selesai! Sangat bagus untuk hal-hal di mana Anda tidak perlu menunggu mereka berakhir.
&!
ke latar belakang pekerjaan dan singkirkan dari shell!
bash
.
nohup
menyelesaikan ini.
Tab selesai . Seberapa burukkah itu jika Anda harus mengetikkan semua karakter dari setiap jalur?
rm -fr /
. Jadi ya, penyelesaian Tab sangat penting ...
ls /usr/lib/game-d*/rott*
rm -rf /
dinonaktifkan di sebagian besar sistem Linux?
Umount perangkat yang terakhir dipasang:
mount /media/whatever
...
u!mo
!mo
memperluas ke perintah terakhir yang dimulai dengan mo
(setidaknya dalam bash). Terkadang seseorang melakukannya mv
di tengah, jadi u!m
tidak akan bekerja sesering mungkin.
Saya memiliki ini di .bashrc saya
#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]"
}
Dan ketika saya memiliki kode sumber html di clipboard dan ingin menemukan semua tautan yang saya gunakan
c-v | find-all 'href="([^"]*)"' | c-c
Dan saya memiliki semua url di clipboard
Saya juga punya fungsi ini
function lsq(){
ls -lh $@ | tr -s ' ' | cut -d' ' -f5,8
}
yang ukuran tampilan (dapat dibaca manusia) dan nama file.
alias temp='cat /proc/acpi/thermal_zone/THRM/temperature'
alias ini untuk acara temerature
function separate() {
python -c "import sys,re; print '$1'.join(re.split('\s*', sys.stdin.read().strip()))";
}
dengan fungsi ini saya dapat menghitung produk atau jumlah argumen.
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()))";
}
Ini adalah fungsi yang berguna yang membagi input standar dipisahkan oleh regex dan kemudian bergabung dengan hasilnya.
function factorial() {
seq -s* $1 | bc
}
fungsi faktorial
function wiki() { dig +short txt $1.wp.dg.cx; }
Fungsi ini menampilkan teks wiki melalui DNS
Saya juga memiliki tiga fungsi warna
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]
}
Fungsi ini memvalidasi hash file md5.
ini akan menampilkan pesan kesalahan untuk kode yang diberikan
function strerror() { python -c "import os; print os.strerror($1)"; }
Anda dapat mencetak semua pesan dengan
alias all-errors='for i in `seq 131`; do echo -n "$i: "; strerror $i; done'
Trik ZSH lain yang bermanfaat:
Perlakukan output dari perintah sebagai file:
emacs =(hg cat -r 100 somefile)
Ini membuka versi lama file Mercurial-dilacak di emacs untuk melihat sintaks yang disorot. Tanpa itu, saya harus dipusingkan dengan hg revert
, hg archive
atau secara eksplisit mengirim hg cat
output ke file sementara.
Tentu saja, ini berfungsi dengan program apa pun yang membuka file, dan program apa pun yang mencetak ke output standar.
Sebuah fitur zsh-spesifik alias akhiran, ditetapkan dengan memberikan alias
para -s
bendera:
alias -s ext=program
Jika ekstensi yang diberikan memiliki alias suffix, Anda dapat menjalankan file dengan ekstensi itu secara langsung, dan ZSH akan meluncurkan program yang diberikan dan meneruskan nama file sebagai argumen. Jadi, jika alias di atas berlaku, garis-garis ini setara:
/path/to/foo.ext
program /path/to/foo.ext
Salah satu fitur ZSH favorit saya sepanjang masa adalah bernama direktori. Anda bisa mengekspor variabel dengan nama yang diberikan, dengan nilai yang menunjuk ke jalur tertentu:
export foo=/usr/bin
Sekarang Anda dapat menggunakan ~foo
perintah untuk merujuk ke /usr/bin
:
cd ~foo
~foo/ls
cat ~foo/filename
Lihat pertanyaan ini .
Ketika Anda menjalankan 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
baris terakhir berisi grep
sesuatu yang agak mengganggu
Anda dapat membebaskan diri dari hal ini dengan menjalankan 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
perbarui : atau jalankan sajapgrep string
'[o]penbox'
). Tanda kurung akan berfungsi sebagai semacam bola, jadi jika ada openbox di direktori Anda (misalkan Anda berada /usr/bin
) bash hanya akan menggunakan openbox, yang akan mencegah trik grep.
Perintah do-nothing :
seperti pada
while :; do :; done
Perluasan brace dalam kombinasi dengan untuk loop:
for c in {1..3}; do :; done
!
operator dan operator hubungan arus pendek ||
dan&&
[ -d /tmp/dir ] || mkdir /tmp/dir
if ! ping 34.41.34.1; then :; fi
menggunakan sub shell bukannya pop / push (berguna dalam skrip)
~$ ( cd /tmp; echo $PWD )
/tmp
~$
jenis- apa-apa perintahtype
~$ type type
type is a shell builtin
~$ type ls
ls is aliased to `ls --color=auto'
~$ f(){ :; }
~$ type f
f is a function
f ()
{
:
}
juga sangat bagus: di sini-string
~$ cat <<<"here $PWD"
here /home/yourname
~$
dan favorit saya: pengalihan pada daftar perintah
{ w; ps; ls /tmp; } 2>/dev/null |less
Saya suka membuang barang sebanyak yang saya bisa ke PS1 saya. Beberapa hal berguna untuk diingat:
\e[s
dan \e[u
simpan dan hapuskan posisi kursor masing-masing. Saya menggunakan ini untuk membuat 'info-bar' di bagian atas layar, panjang beberapa baris, yang dapat memuat lebih banyak barang. Contoh:
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\]\$ '
Kombinasikan dengan alias clear='echo -e "\e[2J\n"'
. Cobalah!
Juga, PROMPT_COMMAND
variabel mendefinisikan perintah untuk dieksekusi sebelum PS1 setiap kali.
Satu lagi adalah bg
perintah. Jika Anda lupa untuk meletakkan &
di akhir perintah, cukup tekan ^Zdan ketik bg
, dan itu berjalan di latar belakang.
bg
, ketika saya memiliki program yang berjalan di latar belakang dan secara tidak sengaja menekan fg
saya tidak tahu bagaimana mendorongnya kembali: D
PS1
jadi saya memasukkan sebagian besar barang yang saya inginkan ke dalam layar saya ...