Часто используемые трюки и советы при работе с Git.
Хотите дополнить список? Ознакомьтесь с CONTRIBUTING.md
- git-tip - консольная утилита, облегчающая использование всех этих команд. Docker-контейнер можно найти здесь
 
P.S: Все эти команды были проверены в git version 2.7.4 (Apple Git-66)
- Создать новую ветку и переключиться на нее
 - Создать новую ветку без родительской ветки
 - Быстрое переключение на предыдущую ветку
 - Список локальных и удаленных веток
 - Список веток в удаленном репозитории
 - Показать все ветки (в том числе и удаленные ветки), а так же последний коммит в них
 - Переименовать ветку
 - Удалить локальную ветку
 - Удалить ветку в удаленном репозитории
 - Показать название текущей ветки
 - Показать все ветки, не слитые в master
 - Показать список веток, которые уже слиты с веткой master
 - Переместить ветку feature на master и слить ее в мастер
 - Удалить ветки, которые уже слиты с master
 - Найти ветки, которые содержат коммит с указанным хешем
 - Track upstream branch
 
- Принудительно удалить неотслеживаемые файлы
 - Принудительно удалить неотслеживаемые файлы и директории
 - Удалить все файлы, которые находятся в 
.gitignore - Before deleting untracked files/directory, do a dry run to get the list of these files/directories
 - Dry run (any command that supports dry-run flag should do)
 
- Изменить сообщение последнего коммита
 - Изменить предыдущий коммит без изменения сообщения к коммиту
 - Исправить имя автора последнего коммита
 - Reset author, after author has been changed in the global config
 - Создать коммит только с указанными файлами
 - Сделать коммит, обойдя хуки pre-commit и commit-msg
 - Отметить коммит как исправление к указанному коммиту
 
- Показать конфиг и все псевдонимы (alias)
 - Изменить локальный/глобальный конфиг git
 - Изменить текстовый редактор
 - Игнорировать изменения прав доступа к файлам при коммите
 - Сделать git чувствительным к регистру
 - Включить автоматическое исправление опечаток
 - Отключить цветной вывод Git
 - Specific color settings
 - Удалить запись из глобального конфига
 - Reuse recorded resolution, record and reuse previous conflicts resolutions
 - Всегда выполнять перемещение вместо слияния при получении изменений из удаленного репозитория
 - Псевдонимы (alias) для команд Git
 
- Показать изменения с момента последнего коммита
 - Показать все изменения (для файлов которых нет в индексе и которые уже там)
 - Изменения в файлах, которые находятся в индексе
 - Показывать изменения в одну строку
 - Показать список конфликтующих файлов
 - Открыть все конфликтующие файлы в редакторе
 - Список всех файлов, которые были изменены в коммите
 
- Интерактивное добавление файлов в индекс
 - Добавить в индекс часть файла
 - Удалить файл из индекса
 - Удалить все файлы из индекса
 
- Показать логи за определенный период (от-до)
 - Показать коммиты за указанный промежуток времени
 - Показать историю коммитов, сгрупировав их по имени автора
 - Показать историю коммитов, исключив коммиты указанного автора
 - Показать коммиты и изменения в них для определенного файла (даже если он был переименован)
 - List only the root and merge commits
 - Показать незапушенные коммиты
 - Показать все коммиты с момента отделения от ветки master
 - Коммиты в ветке branch-1, которых нет в branch-2
 - Показать GPG-сигнатуру в истории коммитов
 - Показать количество строк, которое добавил/удалил пользователь
 - Поиск в истории коммитов по регулярному выражению
 - Показать все заметки (git notes)
 - Показать дерево тегов (версий)
 - Get first commit in a branch (from master)
 
- Отправить коммиты в удаленный репозиторий, перезаписав историю (force push)
 - Отправить коммиты в удаленный репозиторий с проверкой, что вы не затираете чужие коммиты
 - Автоматически устанавливать remote для ветки при пуше
 
- Спрятать текущие изменения для отслеживаемых файлов
 - Спрятать текущие изменения, включая неотслеживаемые файлы
 - Спрятать текущие изменения за исключением файлов в индексе
 - Спрятать только часть файла (файлов)
 - Показать список спрятанных изменений
 - Применить последние спрятанные изменения и удалить их из стека
 - Применить последние спрятанные изменения без удаления их из стека
 - Извлечь отдельный файл из stash
 - Очистить stash
 
- Создать новый тег
 - Отправить теги на удаленный репозиторий
 - Удалить тег в локальном репозитории
 - Удалить тег в удаленном репозитории
 
- Everyday Git in twenty commands or so
 - Show helpful guides that come with Git
 - Клонировать отдельную ветку
 - Клонировать репозиторий с указаным количеством коммитов
 - Импортировать пакет в репозиторий
 - Alias: git undo
 - Получить данные из удаленного репозитория и сбросить состояние текущей ветки к ним
 - Prunes references to remote branches that have been deleted in the remote
 - Загрузить пулл-реквест в текущую ветку по ID
 - Specific fetch reference
 - List of all files till a commit
 - Git reset first commit
 - Показать самый последний тег на текущей ветке
 - Revert: отменить коммит с помощью нового коммита
 - Revert: отменить слияние (merge) с помощью нового коммита
 - Reset: Отменить коммиты (сброс к указанному коммиту)
 - Показать историю коммитов только для текущей ветки
 - Показать список удаленных репозиториев
 - Изменить URL удаленного репозитория
 - List references in a remote repository
 - Добавить удаленный репозиторий
 - Автокомплит Git-команд в bash
 - Перенести коммиты из одной ветки в другую с помощью cherry-pick
 - Undo local changes with the last content in head
 - Показать все отслеживаемы файлы
 - Показать все неотслеживаемые файлы
 - Показать все игнорируемые файлы
 - Create new working tree from a repository (git 2.5)
 - Create new working tree from HEAD state
 - Не отслеживать файл (без удаления)
 - Обновить все субмодули
 - Показать коммиты текущей ветки, которые будут слиты в мастер
 - Retrieve the commit hash of the initial revision
 - Deploying git tracked subfolder to gh-pages
 - Adding a project to repo using subtree
 - Get latest changes in your repo for a linked project using subtree
 - Экспортировать ветку в файл (создать пакет)
 - Архивировать ветку master
 - Ignore one file on commit (e.g. Changelog)
 - Спрятать изменения перед выполнением перемещения
 - Show changes using common diff tools
 - Don’t consider changes for tracked file
 - Undo assume-unchanged
 - Восстановить удаленный файл
 - Restore file to a specific commit-hash
 - Check if the change was a part of a release
 - Squash fixup commits normal commits
 - Показать список игнорируемых файлов
 - Статус игнорируемых файлов
 - Count unpacked number of objects and their disk consumption
 - Prune all unreachable objects from the object database
 - Instantly browse your working repository in gitweb
 - Получить файл из другой ветки
 - Изменить коммиты в интерактивном режиме
 - Поиск коммита с багом при помощи бинарного поиска
 - Показать все локальные ветки, отсортировав их по дате изменения
 - Find lines matching the pattern (regex or string) in tracked files
 - Количество коммитов в ветке
 - Добавить заметку
 - Apply commit from another repository
 - Найти общего предка двух веток
 - Показывает автора, время и хеш-коммита последнего изменения для каждой строки файла
 - Показывает автора, время и хеш-коммита последнего изменения для указанного диапазона строк
 - Show a Git logical variable
 - Preformatted patch file
 - Показать название репозитория
 - Generates a summary of pending changes
 - Сделать резервную копию неотслеживаемых файлов
 
git checkout -b <branch-name>Alternatives:
git branch <branch-name> && git checkout <branch-name>git checkout --orphan <branch-name>git checkout -git branch -agit branch -rgit branch -vvgit branch -m <new-branch-name>Alternatives:
git branch -m [<old-branch-name>] <new-branch-name>git branch -d <local-branch-name>git push origin --delete <remote-branch-name>Alternatives:
git push origin :<remote-branch-name>git rev-parse --abbrev-ref HEADgit checkout master && git branch --no-mergedgit branch --merged mastergit rebase master feature && git checkout master && git merge -git branch --merged master | grep -v '^\*' | xargs -n 1 git branch -dAlternatives:
git branch --merged master | grep -v '^\*\|  master' | xargs -n 1 git branch -d # will not delete master if master is not checked outgit branch -a --contains <commit-ish>Alternatives:
git branch --contains <commit-ish>git branch -u origin/mybranchgit clean -fgit clean -f -dAlternatives:
git clean -dfgit clean -X -fgit clean -ngit clean -fd --dry-runПри выполнении команды откроется редактор, указанный в настройках git. Необходимо изменить текст сообщения, сохранить файл и закрыть редактор.
Сообщение можно указать и непосредственно при вызове команды с помощью опции -m (--message)
git commit --amend
# можно указать сообщение с помощью опции -m
git commit --amend -m "New message"git commit --amend --no-editgit commit --amend --no-edit --author='Author Name <[email protected]>'git commit --amend --reset-author --no-editgit commit --only <file_path>git commit --no-verifyAlternatives:
git commit -ngit commit --fixup <SHA-1>git config --listgit config [--global] --editgit config --global core.editor '$EDITOR'git config core.fileMode falsegit config --global core.ignorecase falsegit config --global help.autocorrect 1git config --global color.ui falsegit config --global <specific command e.g branch, diff> <true, false or always>git config --global --unset <entry-name>git config --global rerere.enabled 1git config --global pull.rebase trueAlternatives:
#git < 1.7.9
git config --global branch.autosetuprebase alwaysgit config --global alias.<handle> <command> 
git config --global alias.st statusgit diffgit diff HEADgit diff --cachedAlternatives:
git diff --stagedgit diff --word-diffgit diff --name-only --diff-filter=Ugit diff --name-only | uniq | xargs $EDITORgit diff-tree --no-commit-id --name-only -r <commit-ish>git add -igit add -pgit reset HEAD <file-name>git reset HEADgit log --since='FEB 1 2017' --until='FEB 14 2017'git log --no-merges --raw --since='2 weeks ago'Alternatives:
git whatchanged --since='2 weeks ago'git shortloggit log --perl-regexp --author='^((?!excluded-author-regex).*)
git log --follow -p -- <file_path>git log --first-parentgit log --branches --not --remotesAlternatives:
git log @{u}..git cherry -vgit log --no-merges --stat --reverse master..git log branch-1 ^branch-2git log --show-signaturegit log --author='Your Name Here' --pretty=tformat: --numstat | gawk '{ add += <!-- @doxie.inject start -->; subs += <!-- @doxie.inject end -->; loc += <!-- @doxie.inject start --> - <!-- @doxie.inject end --> } END { printf "added lines: %s removed lines: %s total lines: %s
", add, subs, loc }' -Alternatives:
git log --author='Your Name Here' --pretty=tformat: --numstat | awk '{ add += <!-- @doxie.inject start -->; subs += <!-- @doxie.inject end -->; loc += <!-- @doxie.inject start --> - <!-- @doxie.inject end --> } END { printf "added lines: %s, removed lines: %s, total lines: %s
", add, subs, loc }' - # on Mac OSXgit log --all --grep='<given-text>'git log --show-notes='*'git log --pretty=oneline --graph --decorate --allAlternatives:
gitk --allgit log master..<branch-name> --oneline | tail -1При этом коммит слияния не будет создан, вам нужно будет сделать его вручную.
git merge feature --squashgit push --forceAlternatives:
git push -fgit push --force-with-lease <remote-name> <branch-name>git config --global push.autoSetupRemote true Также можно использовать HEAD~1, HEAD~2 и т.д. для просмотра предыдущих коммитов.
git show HEADgit show <commit-ish>git stashAlternatives:
git stash savegit stash -uAlternatives:
git stash --include-untrackedgit stash --keep-indexПозволяет выбрать изменения, которые необходимо скрыть
git stash -pgit stash listgit stash popAlternatives:
git stash apply stash@{0} && git stash drop stash@{0}git stash apply <stash@{n}>git checkout <stash@{n}> -- <file_path>Alternatives:
git checkout stash@{0} -- <file_path>git stash clearAlternatives:
git stash drop <stash@{n}>git tag <tag-name>git push --tagsgit tag -d <tag-name>git push origin :refs/tags/<tag-name>Alternatives:
git push origin :<tag-name>git push -d origin <tag-name>git help everydaygit help -ggit clone -b <branch-name> --single-branch https://github.com/user/repo.gitgit clone https://github.com/user/repo.git --depth 1git clone repo.bundle <repo-dir> -b <branch-name>git config --global alias.undo '!f() { git reset --hard $(git rev-parse --abbrev-ref HEAD)@{${1-1}}; }; f'git fetch --all && git reset --hard origin/mastergit fetch -pAlternatives:
git remote prune origingit fetch origin pull/<id>/head:<branch-name>Alternatives:
git pull origin pull/<id>/head:<branch-name>git fetch origin master:refs/remotes/origin/mymastergit ls-tree --name-only -r <commit-ish>git update-ref -d HEADgit describe --tags --abbrev=0git revert <commit-ish>git revert -m 1 <commit-ish>git reset <commit-ish>git cherry -v mastergit remoteAlternatives:
git remote showgit remote set-url origin <URL>git ls-remote git://git.kernel.org/pub/scm/git/git.gitgit remote add <remote-nickname> <remote-url>curl http://git.io/vfhol > ~/.git-completion.bash && echo '[ -f ~/.git-completion.bash ] && . ~/.git-completion.bash' >> ~/.bashrcgit checkout <branch-name> && git cherry-pick <commit-ish>git checkout -- <file_name>git ls-files -tgit ls-files --othersgit ls-files --others -i --exclude-standardgit worktree add -b <branch-name> <path> <start-point>git worktree add --detach <path> HEADУдаляет файл из git, сохраняя при этом его локальную копию
git rm --cached <file_path>Alternatives:
git rm --cached -r <directory_path>git submodule foreach git pullAlternatives:
git submodule update --init --recursivegit submodule update --remotegit cherry -v masterAlternatives:
git cherry -v master <branch-to-be-merged> git rev-list --reverse HEAD | head -1Alternatives:
git rev-list --max-parents=0 HEADgit log --pretty=oneline | tail -1 | cut -c 1-40git log --pretty=oneline --reverse | head -1 | cut -c 1-40git subtree push --prefix subfolder_name origin gh-pagesgit subtree add --prefix=<directory_name>/<project_name> --squash [email protected]:<username>/<project_name>.git mastergit subtree pull --prefix=<directory_name>/<project_name> --squash [email protected]:<username>/<project_name>.git mastergit bundle create <file> <branch-name>git archive master --format=zip --output=master.zipgit update-index --assume-unchanged Changelog; git commit -a; git update-index --no-assume-unchanged Changeloggit rebase --autostashgit difftool -t <commit1> <commit2> <path>git update-index --assume-unchanged <file_name>git update-index --no-assume-unchanged <file_name>git checkout <deleting_commit>^ -- <file_path>git checkout <commit-ish> -- <file_path>git name-rev --name-only <SHA-1>git rebase -i --autosquashgit check-ignore *git status --ignoredgit count-objects --human-readablegit gc --prune=now --aggressivegit instaweb [--local] [--httpd=<httpd>] [--port=<port>] [--browser=<browser>]git show <branch_name>:<file_name>git rebase --interactive HEAD~2git bisect start                    # Search start 
git bisect bad                      # Set point to bad commit 
git bisect good v2.6.13-rc2         # Set point to good commit|tag 
git bisect bad                      # Say current state is bad 
git bisect good                     # Say current state is good 
git bisect reset                    # Finish search 
git for-each-ref --sort=-committerdate --format='%(refname:short)' refs/heads/git grep --heading --line-number 'foo bar'git rev-list --count <branch-name>git notes add -m 'Note on the previous commit....'git --git-dir=<source-dir>/.git format-patch -k -1 --stdout <SHA1> | git am -3 -kdiff -u <(git rev-list --first-parent BranchA) <(git rev-list --first-parent BranchB) | sed -ne 's/^ //p' | head -1Также можно выполнить команду с флагом -s для того, чтобы показывать автора и время коммита
git blame <file-name>git blame <file-name> -L <start>,<end>git var -l | <variable>git format-patch -M upstream..topicgit rev-parse --show-toplevelgit request-pull v1.0 https://git.ko.xz/project master:for-linusgit ls-files --others -i --exclude-standard | xargs zip untracked.zip