一.获取库
- git + clone + 地址
二.上传文件
- 追踪或暂存:git + add +
-
提交到本地仓库:git + commit + -m +
git + commit + -a可以跳过暂存 - 上传到远程仓库:git push
三.查看文件
3.1查看状态
- 直接:git status
- 缩略查看:git status -s
- 查看未暂存的修改:git diff
- 查看已暂存的修改:git diff –cached
3.2 查看提交日志
- 查看 提交历史:git log
- -p显示每次提交的差异;
- –stat显示简略信息;
- –pretty=xxx以不同的格式显示提交(比如:oneline,short,full,fuller)
- git log –pretty=format::”%h – %an, %ar : %s”:定制要显示的记录格式,使用占位符
- –graph , 这个选项添加了一些ASCII字符串来形象地展示你的分支、合并历史
四.忽略文件
- 一般我们总会有些文件无需纳入 Git 的管理,也不希望它们总出现在未跟踪文件列表。 通常都是些自动生成的文件,比如日志文件,或者编译过程中创建的临时文件等。 在这种情况下,我们可以创建一个名为 .gitignore 的文件,列出要忽略的文件模式。 来看一个实际的例子:
$ cat .gitignore
*.[oa]
*~
第一行告诉 Git 忽略所有以 .o 或 .a 结尾的文件。一般这类对象文件和存档文件都是编译过程中出现的。 第二行告诉 Git 忽略所有以波浪符(~)结尾的文件,许多文本编辑软件(比如 Emacs)都用这样的文件名保存副本。 此外,你可能还需要忽略 log,tmp 或者 pid 目录,以及自动生成的文档等等。 要养成一开始就设置好 .gitignore 文件的习惯,以免将来误提交这类无用的文件。
文件 .gitignore 的格式规范如下:
所有空行或者以 # 开头的行都会被 Git 忽略。可以使用标准的 glob 模式匹配。匹配模式可以以(/)开头防止递归。匹配模式可以以(/)结尾指定目录。要忽略指定模式以外的文件或目录,可以在模式前加上惊叹号(!)取反。
所谓的 glob 模式是指 shell 所使用的简化了的正则表达式。 星号(
)匹配零个或多个任意字符;[abc]匹配任何一个列在方括号中的字符(这个例子要么匹配一个字符 a,要么匹配一个字符 b,要么匹配一个字符 c);问号(?)只匹配一个任意字符;如果在方括号中使用短划线分隔两个字符,表示所有在这两个字符范围内的都可以匹配(比如 [0-9] 表示匹配所有 0 到 9 的数字)。 使用两个星号(
) 表示匹配任意中间目录,比如a/**/z 可以匹配 a/z, a/b/z 或 a/b/c/z等。
下面再看一个 .gitignore 文件的例子:
# no .a files
*.a
# but do track lib.a, even though you're ignoring .a files above
!lib.a
# only ignore the TODO file in the current directory, not subdir/TODO
/TODO
# ignore all files in the build/ directory
build/
# ignore doc/notes.txt, but not doc/server/arch.txt
doc/*.txt
# ignore all .pdf files in the doc/ directory
doc/**/*.pdf
Shell
五.移除文件
- git + rm + filename
- git + rm + *~: 删除以 ‘’
- git + rm + name + –cached:磁盘中保留,暂存区中删除
- git + rm + path/*.log:批量删除path下的以.log结尾的文件
六.移动文件
- git + mv + file1 +file2:实际上是重命名了文件,进行了以下操作
$ mv file1 file2
$ git rm file1
$ git add file2
七.撤销操作
- git commit –amend:重新提交
- git reset HEAD :取消暂存
- git checkout – :取消对文件的修改
八.远程操作
-
git remote:显示每个远程仓库服务器
-v,会显示需要读写远程仓库使用的 Git 保存的简写与其对应的 URL -
git remote add :添加一个新的远程 Git 仓库,同时指定一个可以轻松引用的简写
在命令行中使用字符串 shortname 来代替整个 url -
git fetch [remote-name]:从远程仓库拉取到本地仓库,它并不会自动合并或修改当前的工作
git pull:从最初克隆的服务器上抓取数据并自动尝试合并到当前所在的分支。 - git push [remote-name] [branch-name]:推送到远程仓库
- git remote show [remote-name]:查看远程仓库
- git remote rename name1 name2;将远程仓库name1重命名name2
- git remote rm:移除一个远程仓库
- git branch -M :切换远程仓库分支
- git push git-start –delete master:删除一个远程分支
九.分支创建和提交
- git branch :查看本地所有分支
- git branch -a :查看本地所有分支和已提交的远程分支
- git branch [branch-name]:创建本地分支
- git checkout [branch-name]:切换到其他分支
- git merge branch:将branch合并到当前分支中
- git branch -d:删除一个分支
版权声明:本文为qq_42102650原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。