Переход с bash на zsh [закрыто]

Я подумываю о переходе с bash на zsh, так как часто сталкиваюсь с сообщениями, в которых хвалят zsh. Я опытный пользователь командной строки, и я предполагаю, что основы почти такие же, поэтому мне нужен совет, чтобы узнать о преимуществах перемещения, и любые подводные камни, о которых следует знать.

Пожалуйста, дайте один совет за каждый ответ. Я ищу небольшие фрагменты, где я могу вернуться и интегрировать дополнительные биты информации в свою оболочку в постоянном темпе, вместо того, чтобы пытаться изучить все это за один раз.

143
задан 7 August 2010 в 16:40

10 ответов

Как вы говорите, zsh во многом похож на bash. У него есть некоторые функции, которых вы не найдете в bash, и он может быть расширен мощными способами. Не думайте о движении как о революции, а скорее как о серии эволюционных шагов, которые помогут вам в вашей повседневной работе. Вот несколько подсказок из моего .zshrc. Хотя вы говорите, что предпочитаете отдельные советы, этот пост - длинный список. Тем не менее, это хорошая идея, чтобы просмотреть пункты по одному. Просто добавьте интересные биты в ваш ~/.zshrc и перезагрузите с source ~/.zshrc. Последний совет: изучите нажатия клавиш сочетаний клавиш по умолчанию zsh («Emacs»): ^A ^E ^W Alt-F Alt-B Alt-P ^L ^R. Вы можете заменить Alt двумя отдельными нажатиями клавиш: Alt-P эквивалентно ESC P.


Это дает вам более полное завершение вкладки.

autoload -U compinit
compinit

Завершение вкладки с обоих концов.

setopt completeinword

Заполнение табуляции должно выполняться без учета регистра.

zstyle ':completion:*' matcher-list 'm:{a-zA-Z}={A-Za-z}'

Лучшее завершение для killall.

zstyle ':completion:*:killall:*' command 'ps -u $USER -o cmd'

Изменяет определение слова, например с ^ W.

autoload select-word-style
select-word-style shell

Цвета для ls.

if [[ -x "`whence -p dircolors`" ]]; then
  eval `dircolors`
  alias ls='ls -F --color=auto'
else
  alias ls='ls -F'
fi

Ярлыки для ls.

alias ll='ls -l'
alias la='ls -a'

Одна история для всех открытых оболочек; хранить 10000 записей. Это делает это полезным помощником в памяти, чтобы найти команды, которые вы использовали в прошлый раз для ./configure и т. Д. Используйте Alt-P (команда поиска, которая начинается так) и ^ R (поиск в истории).

HISTFILE=~/.zhistory
HISTSIZE=SAVEHIST=10000
setopt sharehistory
setopt extendedhistory

Включает всевозможные расширенные глобализации, такие как ls ** / *. Txt (найти все текстовые файлы), ls -d *(D) (показать все файлы, включая те, которые начинаются с «.»). Чтобы узнать больше, перейдите в man zshexpn, раздел «Генерация файлов».

# superglobs
setopt extendedglob
unsetopt caseglob

Это полезно для запоминания команд в вашей истории без их выполнения.

setopt interactivecomments # pound sign in interactive prompt

Введите «..» вместо «cd ..», «/ usr / include» вместо «cd /usr/include".

setopt auto_cd

Хорошая подсказка.

PS1='[%T] %n@%m:%~# '

Отображение статистики использования ЦП для команд, занимающих более 10 секунд

REPORTTIME=10

Некоторые команды, которые вы интенсивно используете в Ubuntu.

alias 'a=sudo aptitude'
alias 'ai=sudo aptitude install'
alias 'ar=sudo aptitude remove'
alias 'au=sudo aptitude update'
alias 'ag=sudo aptitude safe-upgrade'
alias 'as=apt-cache search'
alias 'aw=apt-cache show'

Перечисляет пакеты, отсортированные по их размеру - полезно при решении, какие пакеты занимают ваше дисковое пространство.

function apt-list-packages {
  dpkg-query -W --showformat='${Installed-Size} ${Package} ${Status}\n' | grep -v deinstall | sort -n | awk '{print $1" "$2}'
}
0
ответ дан 7 August 2010 в 16:40

Я в той же поездке:)

До сих пор я обнаружил, что дело в том, чтобы иметь хороший файл конфигурации (.zshrc).

Возьмите это в качестве примера http://matt.blissett.me.uk/linux/zsh/zshrc , посмотрите комментарии и взломайте свой путь. Stackoverflow и severphault и хорошие места для поиска тоже.

Мне еще предстоит погрузиться в http://dotfiles.org/.zshrc , но у меня не так много времени, чтобы проиграть:)

0
ответ дан 7 August 2010 в 16:40

Я бы порекомендовал книгу От bash до Z Shell . В нем есть все советы, необходимые для переключения вашей оболочки. Это объясняет различия между обоими оболочками и облегчает новый zsher.

0
ответ дан 7 August 2010 в 16:40

Вот мой .zshrc , и это самая важная вещь! У zsh есть много опций, которые вы можете использовать, так что посмотрите некоторые примеры в сети или прочитайте документацию на домашней странице Zsh .

Мой .zshrc не содержит действительно крутых вещей, кроме метки времени в правой части командной строки.

Кстати, не забудьте попробовать табуляцию каждый раз, когда несколько примеров здесь:

mplayer -a[tab]

покажет что-то вроде этого:

mplayer -a
 -ac                 -- force usage of a specific audio codec
 -af                 -- activate audio filters
 -afm                -- force usage of a specific audio codec family
 -alang              -- select the DVD audio language
 -ao                 -- specify audio driver
 -aop                -- specify audio output filter

И если вы используете ssh-ключи без пароля или ssh-agent вы можете найти его полезным для табуляции завершенных удаленных файлов:

scp apollo:/home/user/[tab]
Desktop/ Documents/ Downloads/ Music/ Pictures/ Public/ Templates/ Videos/

После получения списка вы можете нажимать клавишу tab несколько раз, чтобы переключаться между различными возможностями.

Но будьте осторожны, эта оболочка сделает вас ленивым и заставит вас чувствовать, что стандартная оболочка глупа и раздражает!

0
ответ дан 7 August 2010 в 16:40

Я не знаю так много об ударе, таким образом, я не могу конкурировать. Некоторые отрывки из моего zsh файла конфигурации.

Некоторая конфигурация

HISTFILE=~/.zsh_history
HISTSIZE=1000
SAVEHIST=1000
REPORTTIME=10 # print elapsed time when more than 10 seconds
setopt NO_HUP
setopt NO_LIST_BEEP
setopt LOCAL_OPTIONS # allow functions to have local options
setopt LOCAL_TRAPS # allow functions to have local traps
setopt HIST_VERIFY
setopt SHARE_HISTORY # share history between sessions ???
setopt EXTENDED_HISTORY # add timestamps to history
setopt PROMPT_SUBST
setopt CORRECT
setopt COMPLETE_IN_WORD
setopt IGNORE_EOF

setopt APPEND_HISTORY # adds history
setopt INC_APPEND_HISTORY SHARE_HISTORY  # adds history incrementally and share it across sessions
setopt HIST_IGNORE_ALL_DUPS  # don't record dupes in history
setopt HIST_REDUCE_BLANKS
# Leave some chars out of the out of WORDCHARS so ^W acts more nicely 
WORDCHARS='*?_-[]~\!#$%^(){}<>|`@#$%^*()+:?'

Мерзавец в подсказке

if [[ -n $SSH_CONNECTION ]]; then
  export PS1='%m:%3~$(git_info_for_prompt)%# '
else
  export PS1='%3~$(git_info_for_prompt)%# '
fi

Некоторые горячие клавиши, вставьте в начале строки некоторый текст.

insert_sudo     () { zle beginning-of-line; zle -U "sudo "         }
insert_apt      () { zle beginning-of-line; zle -U "sudo apt-get " }
insert_gem      () { zle beginning-of-line; zle -U "sudo gem "     }
insert_install  () { zle -U "install "     }

zle -N insert-sudo      insert_sudo
zle -N insert-apt       insert_apt
zle -N insert-gem       insert_gem
zle -N insert-install   insert_install

bindkey "^B" insert-gem
bindkey "^N" insert-install
bindkey "^k" insert-sudo
bindkey "^a" insert-apt

Функции, я храню затем в ~/.zsh/functions

git_info_for_prompt

local g="$(git rev-parse --git-dir 2>/dev/null)"
if [ -n "$g" ]; then
  local r
  local b
  if [ -d "$g/../.dotest" ]
  then
    if test -f "$g/../.dotest/rebasing"
    then
      r="|REBASE"
    elif test -f "$g/../.dotest/applying"
    then
      r="|AM"
    else
      r="|AM/REBASE"
    fi
    b="$(git symbolic-ref HEAD 2>/dev/null)"
  elif [ -f "$g/.dotest-merge/interactive" ]
  then
    r="|REBASE-i"
    b="$(cat "$g/.dotest-merge/head-name")"
  elif [ -d "$g/.dotest-merge" ]
  then
    r="|REBASE-m"
    b="$(cat "$g/.dotest-merge/head-name")"
  elif [ -f "$g/MERGE_HEAD" ]
  then
    r="|MERGING"
    b="$(git symbolic-ref HEAD 2>/dev/null)"
  else
    if [ -f "$g/BISECT_LOG" ]
    then
      r="|BISECTING"
    fi
    if ! b="$(git symbolic-ref HEAD 2>/dev/null)"
    then
      if ! b="tag: $(git describe --exact-match HEAD 2>/dev/null)"
      then
        b="$(cut -c1-7 "$g/HEAD")..."
      fi
    fi
  fi

  if [ -n "$1" ]; then
    printf "$1" "${b##refs/heads/}$r"
  else
    printf "[%s]" "${b##refs/heads/}$r"
  fi
fi

Некоторые опции GitHub

#compdef github

_github() {
  if (( CURRENT > 2 )); then
    # shift words so _arguments doesn't have to be concerned with second command
    (( CURRENT-- ))
    shift words
    # use _call_function here in case it doesn't exist
    _call_function 1 _github_${words[1]}
  else
    _values "github command" \
     "fetch[Fetch from a remote to a local branch.]" \
     "ignore[Ignore a SHA (from 'github network commits')]" \
     "fetch_all[Fetch all refs from a user]" \
     "info[Info about this project.]" \
     "browse[Open this repo in a web browser.]" \
     "home[Open this repo's master branch in a web browser.]" \
     "clone[Clone a repo.]" \
     "pull-request[Generate the text for a pull request.]" \
     "network[Project network tools.]" \
     "pull[Pull from a remote.]" \
     "track[Track another user's repository.]"
  fi
}

_github_pull() {
  _arguments \
    "--merge[Automatically merge remote's changes into your master.]"
}
_github_clone() {
  _arguments \
    "--ssh[Clone using the git@github.com style url.]"
}

_github_track() {
  _arguments \
    "--private[Use git@github.com: instead of git://github.com/.]" \
    "--ssh[Equivalent to --private.]"
}

_github_network() {
  if (( CURRENT > 2 )); then
    # shift words so _arguments doesn't have to be concerned with second command
    (( CURRENT-- ))
    shift words
    # use _call_function here in case it doesn't exist
    _call_function 1 _github_network_${words[1]}
  else
    _values "github network command" \
     "web[Open network in a web browser.]" \
     "list[List networked repositories.]" \
     "fetch[Fetched commits for a given networked repository.]" \
     "commits[List networked commits not pulled into this repo.]"
  fi
}

_github_network_commits() {
  _arguments \
    "--project[Filter commits on a certain project.]" \
    "--author[Filter commits on a email address of author.]" \
    "--common[Show common branch point.]" \
    "--nocache[Do not use the cached network data.]" \
    "--sort[How to sort : date(*), branch, author.]" \
    "--thisbranch[Look at branches that match the current one]" \
    "--applies[Filter commits to patches that apply cleanly.]" \
    "--limit[Only look through the first X heads - useful for really large projects]" \
    "--before[Only show commits before a certain date.]" \
    "--after[Only show commits after a certain date.]" \
    "--shas[Only show shas.]" \
    "--cache[Use the network data even if it's expired.]" \
    "--noapply[Filter commits to patches that do not apply cleanly.]"
}
4
ответ дан 7 August 2010 в 16:40

Я дал пару разговоров и обратил несколько человек в Zsh. Здесь я храню репозиторий github моих (каковы преимущества) заметок, а также стартовый файл и копию моей собственной конфигурации zsh в github.

http://github.com/mitechie/zshrc

0
ответ дан 7 August 2010 в 16:40

Большое преимущество - превосходное завершение табуляции с помощью предварительно упакованных скриптов завершения для многих команд. Вот пример, показывающий вывод apt-get<TAB>:

apt-get
action
autoclean        build-dep        clean            dselect-upgrade  install          remove           update           
autoremove       check            dist-upgrade     help             purge            source           upgrade          
0
ответ дан 7 August 2010 в 16:40

Другим важным источником информации является страница любителей zsh (взято с grml zsh site ).

0
ответ дан 7 August 2010 в 16:40

Узнайте о расширенном globbing и рекурсивных шариках в zsh.

Узнайте немного о zstyle и как различные вещи (особенно завершение) позволяют Вам настроить их конфигурацию с помощью zstyle.

Изучите ассоциативные массивы. Также стандартные массивы (остерегаются различий от удара, к лучшему!)

Если Вы используете регулярные выражения, изучаете =~ (которые колотят, также имеет), и рассмотрите: setopt rematch_pcre

Постарайтесь не писать сценарии, которые зависят от больше, чем определенного волшебства zsh, потому что, в то время как это фантастически для использования, zsh может склоняться к тому, чтобы быть только для записи. При использовании еще много думайте о том, когда переключиться на язык, такой как Python.

Zsh обольстителен. Это - темная сторона.Добро пожаловать.

3
ответ дан 7 August 2010 в 16:40

Несколько особенно полезных расширенных глобусов:

1- rmdir *(/^F) - удалить все непустые каталоги в текущем каталоге

2- grep traceback /srv/log/**/*(.m-2) - найти это регулярное выражение в файлы, измененные за последние два дня

3- chmod g+w **/*(U^I) - все файлы, принадлежащие мне и не доступные для записи в группе, могут быть доступны для записи в группе

Да, конечно, вы можете написать это с помощью find но это легче накатать. Если честно, у него есть два недостатка, оба из которых связаны с тем, что все они развернуты в командной строке: если она соответствует многим тысячам файлов, командная строка будет слишком длинной, и это не удастся, а во-вторых, все файлы найдены. до запуска файла.

(Вам понадобится setopt extendedglob, если он еще не включен)

0
ответ дан 7 August 2010 в 16:40

Другие вопросы по тегам:

Похожие вопросы: