你觉得这篇文章怎么样? 帮助我们为您提供更好的内容。
Thank you! Your feedback has been received.
There was a problem submitting your feedback, please try again later.
你觉得这篇文章怎么样?
Git简介
介绍github之前先来介绍一下git,git是拿来做版本控制的工具,从下面那张图就可以发现很多人在文件名命名的时候不会做版本控管,这样其实很难知道到底哪一个是最新版本的。
所以我们通常在文件名上就会给予版本、功能、时间之类的,让档案第一眼就能看出来版本的差异:
那如果是项目呢?众多程序代码不可能一个一个地去改名,所以就有git的出现了,他可以协助你管理程序的版本。
那比较常听到的github就是git推出的代管服务平台,使用者可以将项目上传到github中来做版本控管以及协作,而github是个免费开源的平台,所以只要注册账号就可以将你的项目分享至网络上给大家使用,如果不想要公开的话就需要成为github的付费会员。
首先我们要先安装Git,通常会直接侦测到你的计算机版本,当然也可以自行选择要安装的版本,通常我在开发Jetson Nano等开发版的项目,都会先在Windows中写好程序再远程进开发版中执行,所以我先使用Windows版本的git来做介绍:
Git安装过程
基本上一直点选下一步就行了,有几个重点稍微介绍一下,他可以选择Git要用的主要编辑器,Git其实比较偏向Linux端,不管是底层还是操作方式都是,所以比较不推荐第三方的编辑器,或多或少会有些许的问题存在,预设是Vim。
接着会问你是否加入环境变量让第三方的终端机等也能使用,一样选择预设就好,预设的状况下是Git提供的平台以及Windwos的Command Prompt、Power Shell等终端机可以使用。
剩下的建议一直下一步即可,像是后端的函式库等等的,安装完之后就会看到开始菜单已经出现Git新安装的软件了,它不仅提供了一个图形化接口的Git
也有提供Bash形式的Git,注意这里使用的都是linux指令像是ls、pwd、touch、cat等基本的Linux指令
而大部分的使用还是会以命令行的方式来运行会比较顺畅,甚至有些功能在图形化的git是无法做到的。
Git操作
前面有说git是为了版本管理而生的,所以我们其实可以针对计算机中的任何一个项目产生git的纪录,那这边我们先新增一个 test_1109 ,接着要先进行初始化,初始化前后的差别在于会出现git的隐藏档:
$ mkdir test_1109
$ cd test_1109
$ git init
$ ls -la
Git隐藏档中就会藏有各种版本应该有的信息,先知道有这个信息即可,接着透过下列指令来查看目前版本的纪录,我们现在没有任何的档案跟纪录所以会报错是正常的:
$ git log
我们来尝试做一些更动,先新增一个档案,在linux中可以直接透过touch来新增一个空白的档案,也可以透过vim、nano等编辑器直接新增档案:
$ touch 01.txt
透过编辑器新增档案的差别只在于必须先给一定的内容才会新增,至于编辑器的使用方法先不多作介绍了:
$ vim 02.txt
在linux的指令中可以透过cat来查看档案内容:
$ cat 01.txt
$ cat 02.txt
我们可以透过status来查看现在git的状态:
$ git status
可以注意到我们都还没有记录任何版本信息所以会显示「No commits yet」,一旦我们纪录了版本信息,当下所有的档案都会变成被追踪状态;红色的字是文件夹中异动的内容,通常出现红字都是有问题的,这时候的问题就是这些档案没有被追踪的,它也有提供应该要做的解决办法 ( use “git add” to track ),接着我们就需要把刚刚异动的档案都加入追踪,后面接档名、--all、-A:
$ git add {file_name}
$ git add --all
$ git add -A
在执行一次status就可以看到档案都没有红字了,代表都已经加入追踪,接着就要提供一个说明:
$ git commit -m “add new file”
如果你像我一样第一次使用,会出现这样的错误讯息,原因是还没登入github使用者,只要登入之后在执行一次就可以了:
$ git config --global user.email "you@example.com"
$ git config --global user.name "Your Name"
$ git commit -m “add new file”
接着只需要输入”git log”就可以查看到刚刚所作的变动,比较特别的地方是每一个说明都会有一组标识符,可以透过这个标识符来直接查看该说明的内容:
接着再稍微修改一01.txt的档案,复习一下git的基础操作:
使用git status查看纪录状态,透过add将档案加入追踪:
接着再给予说明,当我们再次使用log来查看纪录的时候可以发现又多了一笔纪录,可注意到的是标识符也截然不同,在当前的纪录后会有 (HEAD -> master)的字样。
既然有了版本管理,那要回复旧版本该怎么办呢?我们透过一个新的范例id.txt来测试一下,首先我在id.txt中添加了chun,接着也增加了 jack,并且用git记录下来两个版本,透过 git log 可以看到有两种版本:
接着我们想要回到前一个版本,执行这行之后可以发现id.txt的内容又变回上一步只有chun的内容了:
$ git reset {标识符} –hard
常见问题:
第一个是有时候命令的前面不小心多了一个空白,第二个则是linux跟windows的换行符号不同所导致的需要在输入 “git config –global core.autocrlf false”来关闭自动转换的功能,之后就不会报错了!
Github & Git
接着我们要结合github来运作,首先要先登入github,在profile页面中找到repositories,并且点击New来新增一个repositories。
进到新增页面之后需要输入repositories的拥有者以及名称,github预设都是公开的,如果要改成私人的话就要付费,其中有几个初始化档案的选项:README、.gitignore、license,README通常为Markdown语法的说明文件,而gitignore则是可以自定义哪些程序或档案不要加入被追踪的行列,而license基本上就是要让其他人使用你的项目的时候能有依据「可以做什么、不能做什么」,这边要注意的是最下面有一个branch (支线)名称我会将其改成 master,再2020年之后原本的master变成了main,但指令的部分老是打错,所以我直接改成master,在setting的部分可以修改。
将原本的项目文件夹上传至Github
这边我以我近期用yolov5撰写的小项目当作范例~
1. 新建github专案,记下网址
2. 开启git bash并前往该项目文件夹执行 git init、git add、git commit等指令
3. 透过remote指令将文件夹链接至github,也能使用-v来查看连结的网址:
$ git remote add <name> <url>
$ git remote -v
4. 连结到之后就可以进行上传 ( push ),在上传之前如果上面已经有档案 (像是README或license) 需要先将数据拉回来 (pull),接着在push出去,都输入完之后就会看到bash的部分开始进行上传。
$ git pull --rebase origin master
$ git push -u origin master
上传之后重新整理可以看到属于master的分支已经更新了
接着我们可以修改一下README.md再更新一次上传的动作,我在README中加入了一些信息,接着一样透过add、commit完成加入repositories
接着直接push上去就可以了:
接着就可以看到README文件已经更新成对应的样式:
结语
其实github还有相当多的功能没有介绍到,本篇文章可以大致了解该怎么透过github来管理自己的项目,控管自己项目的版本了!好好经营自己的github还是很重要的!