Git基本命令 -- 创建Git项目
在这里下载git:https://git-scm.com/
安装的时候, 如果是windows系统的话, 可以勾选unix的命令行工具, 这样在windows命令行下会多出很多命令, 例如ls.
Git基本命令大致分这些, 这一部分只讲创建项目这块.
- 创建git项目
- 基本工作流程 (Workflow)
- 文件相关操作
- 历史和别名
- 忽略文件 (Ignoring)
创建项目
1.开始新项目
git init 项目名:

通过这个命令git创建了一个文件夹叫做learn-git.
进入这个目录, 执行ls命令, 不会看到任何文件:

但是如果执行ls -al命令, 就可以看见以.开头的文件了:

这时就可以看到一个.git文件夹了. git的仓库就在这.
进入这个.git文件夹:

回到工作文件夹 (learn-git).
通过git status命令查看git仓库的状态:

可以看到, 目前是在master分支上, master分支是git的默认分支.
目前还没有任何提交(commit), 也没有任何东西需要commit, 因为我还没有创建任何文件, 那么就开始创建文件吧.
[这里我使用vscode]

然后vscode会创建一个lorem.txt文件, 并打开它.
贴进去一些文字:
Lorem Ipsum is simply dummy text of the printing and typesetting industry. Lorem Ipsum has been the industry's standard dummy text ever since the 1500s, when an unknown printer took a galley of type and scrambled it to make a type specimen book. It has survived not only five centuries, but also the leap into electronic typesetting, remaining essentially unchanged. It was popularised in the 1960s with the release of Letraset sheets containing Lorem Ipsum passages, and more recently with desktop publishing software like Aldus PageMaker including versions of Lorem Ipsum.
如果没有自动换行显示的话, 可以按opt+z:

回到命令行, 再次输入git status查看状态:
这时我们看到了一些变化:

写到是有个文件未被追踪 lorem.txt.
我需要做的就是把这个文件添加到git index或者git staging 区.
这时就使用这个命令: git add lorem.txt.
执行命令后再看一下状态:

这时写到, 有变化需要被提交(commit, 以后说英文吧), 这就是说lorem.txt这个新文件现在处于git的staging区, 等待被commit, 还没有被commit. 我可以移除这个文件, 并且不会有git 仓库(repository)有任何影响. 不过现在我还是想提交它, 所以执行 git commit命令, 如果不带任何参数的话, git将打开默认的编辑器:

我的默认编辑器是vi.
vi的操作是, 输入i, 然后进入insert模式, 就可以输入文字了:

然后按esc, 输入命令:wq 保存并关闭vi. 就会回到原来的命令行.

这里显示了刚才我在git commit时输入的文字, 但是换行没有了, 实际上还有的, 只不过是这里没显示罢了.
还有这个root-commit表示, 这是这个repository的第一个commit.
然后再执行git status:

写到没有需要commit的东西, 工作树是干净的.
这时lorem.txt已经进入了git respository. 这个变化也成了git commit历史的一部分.
2.添加git到现有项目:
需要一个项目, 所以可以访问这个有趣的网站: http://www.initializr.com/ 去生成一个项目:

把这些都勾选上, 这样可以多一些文件.
然后点击Download it.
下载后解压缩该文件, 使用unzip命令:

然后会出现一个initializr目录, 我把这个目录改一下名:

接下来, 进入这个目录, 然后就准备开始把git添加到这个项目了.

使用git init命令, 这时不需要加上项目名参数了:

git就会初始化一个新的repository, 并把当前目录作为working directory 工作目录.
这时就可以看到.git目录了:

查看以下状态 git status:

当前是在master分支, 没有任何commit, 并且有很多未被追踪的文件.
为了把所有这些文件一次性添加到git staging (临时)区和git index (索引), 那就使用命令: git add . 注意这里还有一个点.

git就会把所有的文件都列出来, 因为这个点 . (period) 会把该项目下所有的文件都递归的添加进去.
接下来就是git commit -m "需要写的文字可以写在这里": 这次我是在行内输入的文字, 加参数-m, 然后文字写在双引号内:

这几次命令中还可以看到圆圈里面的文字, 就照着做就行, 进行用户名和邮件的全局配置.
然后再看一下状态 git status:

不出所料.
当前呢, 这个项目/目录是这个git repository的一部分, 之所以称这个working directory是git repository的一部分, 这是因为它下面有个.git目录. 如果把这个目录删除了, 那么它就不再被git所管理了. 下面就这么做一下:
rm -fr .git :

嗯 git status表示这不是一个git repository.
参与Github项目.
先拿张老师的一个项目为例: https://github.com/geffzhang/opendotnet
肯定是需要github账户并登陆的.
fork 项目.

这里, 登陆后, 右上角显示的是我的账户的头像. 左边是该repository的用户以及当前repository的名字.
然后点击fork按钮.

选择我的用户名.

然后, 我就把张老师的项目复制到我的用户名下了, 可以看到左上角是我的用户名, repository名字不变, 还有一个注释, 写的是forked的from原来用户.
随后我要克隆这个项目(clone).

在箭头处复制该repository的地址, 然后打开本地电脑的命令行, 输入命令 git clone repository的地址 来进行clone.
(这里我换了一个项目进行fork, 因为上面这个项目太大了):

可以看到, 项目较大, 进度很慢.
等clone完之后, 进入该文件夹. 可以看到项目文件了:


可以看到.git目录, 里面有文件:

回到上层目录查看状态:

因为这是刚刚clone过来的项目, 所以它是最新的 update to date.
里面的origin 是对这个github repository的远程的引用, /master表示是在这个远程repository的master分支上.
今天就写这些.
这里讲了三种不同为项目添加git的方式.
使用到了几个最常用的命令:
git init, git add, git commit, git status, git clone.
Git基本命令 -- 创建Git项目的更多相关文章
- 如何将git本地创建的项目推送到github仓库
除了集中式的版本控制系统CVS和SVN外,还有目前世界上最先进的分布式版本控制系统Git,它的创始人是创建了linux的大神 - linus.GitHub网站与2008年开始服役,为开源项目免费提供G ...
- Java_eclipse软件与git配合使用创建git仓库
一.在eclipse上安装git,和安装其他插件一样 help->Install new software->add... 在弹出框中输入name,location;点击-->ok ...
- eclipse软件与git配合使用创建git仓库
一.在eclipse上安装git,和安装其他插件一样 help->Install new software->add... 在弹出框中输入name:git,location:http:// ...
- git基本命令和仓库操作
首先git是什么?git是github上的一个代码托管工具,是一款代码版本管理工具,github上的代码是基于git来进行托管的.github是全球的开源社区.Git 保存的不是文件的变化或者差异,而 ...
- git入门 创建版本库, 版本管理 分支 标签
参考: https://www.liaoxuefeng.com/wiki/0013739516305929606dd18361248578c67b8067c8c017b000 GIT最流行的分布式版本 ...
- idea创建springcloud项目图文教程(EurekaServer注册中心)
http://blog.csdn.net/hcmony/article/details/77854999 idea创建springcloud项目图文教程(EurekaServer注册中心)(六) 1, ...
- 【git】搭建git服务器
在 Linux 下搭建 Git 服务器 目录 ① 安装 Git ② 服务器端创建 git 用户,用来管理 Git 服务,并为 git 用户设置密码 ③ 服务器端创建 Git 仓库 ④ 客户端 clon ...
- vs在微软官方tfs创建私有项目过程
谁也不是成天创建新项目,每次一创建就跟没干过这活似的,这次把它记下,再用的时候来翻,也希望能给别人点帮助. 上https://dev.azure.com/,tfs原来的网址会往这里跳,现在都在往dev ...
- 第二章——建立一个HelloWorld项目,练习使用git的add/commit/push/pull/fetch/clone等基本命令。比较项目的新旧版本的差别-----答题者:徐潇瑞
1.首先下载安装git,很简单所以就不详细说了,当弹出一个类似的命令窗口的东西,就说明Git安装成功 2.因为Git是分布式版本控制系统,所以需要填写用户名和邮箱作为一个标识 3.接着,注册githu ...
随机推荐
- centos7下安装vsftpd
安装步骤: 创建ftp目录 cd / mkdir ftpfile 创建指定登陆用户并不让他拥有登陆系统的权限(设置指定登陆shell) useradd ftpuser -d /ftpfile/ -s ...
- Yii2按需加载图片怎么做?
按需加载图片应该用 jQuery LazyLoad 图片延迟加载按需加载文件夹应该用 Yii::import
- 《android开发艺术探索》读书笔记(七)--动画
接上篇<android开发艺术探索>读书笔记(六)--Drawable No1: 自定义动画:派生一种新动画只需要继承Animation这个抽象类,然后重写它的initialize和app ...
- python 小练习之删除文件夹下的所有文件,包括子文件夹中的文件
先屡一下思路 一步步怎么实现 1 要求是要删除所有文件(只是删除文件 而不是文件夹),所以 我们肯定要遍历这个文件目录 (for in遍历) 2 每遍历一个元素时(文件),我们要判断该元素的属性是 ...
- .net core 部署到 iis 步骤及报错解决方法
我写了一个Asp.net core mvc项目,但是部署在iis发生了502.5的问题一直解决不了. 环境 系统:最强Win10; 工具:轻巧VS Code; 各种百度bing都没有我要的解决方案,说 ...
- Django2.0文档
第四章 模板 1.标签 (1)if/else {% if %} 标签检查(evaluate)一个变量,如果这个变量为真(即,变量存在,非空,不是布尔值假),系统会显示在 {% if %} 和 {% e ...
- AttributeError: 'TestLogin' object has no attribute 'driver' in Pycharm for python selenium
自动化测试学习中的问题: 最近几天在写登陆测试,遇到一个问题,困惑我的几个小时......... 我各种百度,花费大量时间,才找到我的问题的根本所在,最终解决了我的问题,主要是大小写的问题def Se ...
- 图像处理------基于Otsu阈值二值化
一:基本原理 该方法是图像二值化处理常见方法之一,在Matlab与OpenCV中均有实现. Otsu Threshing方法是一种基于寻找合适阈值实现二值化的方法,其最重 要的部分是寻找图像二值化阈值 ...
- hi3531的pcie控制器使能
1. 关闭PCIe 控制器: 通过向系统控制寄存器PERIPHCTRL30[pcie0_app_ltssm_enabl]写入0 关闭PCIe0 控制 器. 通过向系统控制寄存器PERIPHCTRL77 ...
- freemarker.core.InvalidReferenceException
1.错误描述 freemarker.core.InvalidReferenceException:on line 68,column 18 in ftl/inc/incPro.ftl p.mainSe ...