Відповіді:
Це дещо розширюється на !!
хитрість, згадану у цій відповіді . Насправді існує купа команд, пов’язаних з історією, про які забули (люди прагнуть колоти Up100 разів замість того, щоб шукати команду, яку вони знають, що вона набрала).
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 чи інших значень читання) замість цього використовується Meta-R (Meta-R також використовується eshell
в Emacs). Тому я часто їх псую.
bash - вставити кінцевий параметр попереднього рядка
alt- . найкорисніша комбінація клавіш коли-небудь, спробуйте і подивіться, чомусь про це ніхто не знає.
натисніть його ще раз і знову, щоб вибрати старіші останні параметри.
чудово, коли ви хочете зробити щось більше для аргументу / файлу, який ви використали лише мить назад.
alt
- .
він перейде до попередньої команди і витягне з неї останній аргумент. Тож якщо ви хочете останній аргумент із трьох команд тому, просто натисніть alt
- .
три рази.
yank-last-arg
readline, тому вона повинна працювати з будь-якою програмою, пов'язаною проти readline, а не тільки з 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 для пошуку / активації раніше виконаних команд (вміст ~ / .bash_history).
Це часто дуже корисно. Запуск цього псевдоніму обслуговуватиме PWD над HTTP (індексовано) на порт 8000:
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
☺
Досить просто, але люди, здається, не знають, повертає вас до попереднього режисера:
cd -
cd..
від DOS врізався в мою м'язову пам’ять ...
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 "$@"; }
І останнє, але не менш важливе, я відмовився від запам'ятовування синтаксису tar, так що:
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
лише на те, що я називаю id md
. Однак використання "$ @" в якості аргументу для CD не має сенсу, оскільки ви не можете використовувати cd у більш ніж одній директорії. "$ @" буде працювати для mkdir, але тоді ви обробляєте аргументи по-різному для mkdir та cd, тому я вважаю за краще запропонуватиmd () { mkdir -p "$1"; cd "$1" }
Дві функції bash, які врятують мене від багатьох клавіш.
Зробіть автоматично ls після кожного успішного компакт-диска:
function cd {
builtin cd "$@" && ls
}
Підніміться на n рівнів:
# 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
у своїх функціях. Handy
cd() { builtin cd -- "$@" && { [ "$PS1" = "" ] || ls -hrt --color; }; }
Оскільки я зазвичай перебуваю на півдорозі до командного рядка перед тим, як захотіти шукати (CTRL-R в баші), у моєму .bashrc є наступне
bind '"\e[A"':history-search-backward
bind '"\e[B"':history-search-forward
Це означає, що якщо я напишу cd, то натискаю вгору / вниз, я можу побачити всі параметри, до яких я ввійшов. В основному я використовую це для часто використовуваних брудів. Як і "cd w", і я закінчую перегляд усіх робочих просторів, які використовую безліч.
Одне, що економить мені багато часу, це команди pushd / popd. Ці хлопці дозволяють вам створити стопку каталогів та зменшити кількість введення тексту:
/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
він перевірить, чи існує ваш основний сеанс, і приєднається до нього. Інакше це створить.
Якщо вам потрібно відредагувати особливо довгий командний рядок у bash
^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
Іноді ваша консоль заплутається, оскільки ви випадково переглянули двійковий файл (наприклад, cat / bin / ls), ви можете відновити термінал за допомогою цієї функції оболонки:
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 від роздратування
Якщо команда приймає введення stdin, ви можете прочитати вхід з файлу з <filename
. Це може з’явитися в будь-якій точці команди, тому ці рядки еквівалентні:
cat filename
cat <filename
<filename cat
Це особливо корисно для grep, оскільки дозволяє розмістити вираз у кінці рядка, тому ви можете швидко змінити команду grep, натиснувши її Up, не потрібно прокручувати ліворуч, щоб пройти повз імені файлу:
<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 /
відключений у більшості систем Linux?
Помістіть останній встановлений пристрій:
mount /media/whatever
...
u!mo
!mo
розгортається до останньої команди, яка почалася з mo
(принаймні, в bash). Іноді хтось робить 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
І у мене є всі URL-адреси в буфері обміну
У мене теж є ця функція
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
висновок у тимчасовий файл.
Звичайно, це працює з будь-якою програмою, яка відкриває файли, та будь-якою програмою, яка друкує до стандартного виводу.
Функція ЗШ-специфічний суфікс псевдонімами, встановлені даючи 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
- це щось трохи неприємне
Ви можете позбутися цього, запустивши 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'
). Дужки будуть працювати як різновид глобуса, тому, якщо у вашому каталозі є openbox (скажімо, ви є /usr/bin
), bash просто використовувати openbox, що запобіжить греп-трюку.
Команда "нічого робити", :
як і в
while :; do :; done
Розширення дужки в поєднанні з для циклів:
for c in {1..3}; do :; done
!
оператора та операторів короткого замикання ||
та&&
[ -d /tmp/dir ] || mkdir /tmp/dir
if ! ping 34.41.34.1; then :; fi
використання допоміжних оболонок замість pop / push (корисно в сценаріях)
~$ ( 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
Я люблю мацати стільки речей, скільки можу в свій PS1. Деякі корисні речі, які потрібно пам’ятати:
\e[s
і \e[u
зберегти і unsave позиції курсора відповідно. Я використовую це для створення "інформаційної панелі" у верхній частині екрана, довжиною пару рядків, яка може вмістити більше матеріалів. Приклад:
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
тому я розміщую більшість потрібних речей у підсумковому екрані ...