GitHub克隆远程项目到本地(可以克隆指定文件夹)以及从本地上传文件到GitHub(Linux和Windows均可,对虚拟机也适用)

1.Git基本操作指令(创建一个Git版本库也就是仓库)

 要想能够比较熟练的使用Git,我们就要学会Git上的一些操作指令,下面就教大家一些Git上最常用的操作指令。
 首先我们要在我们的电脑上创建一个版本库也就是Git的仓库。

第一步:创建一个空目录

 $ mkdir wenjian                   //   创建一个名叫wenjian的目录
 $ cd  wenjian                       //  进入到wenjian的目录下
 $ pwd                                  //显示当前路径,例如我的为home/ubuntu/wenjian
 /home/ubuntu/wejian           

第二步:通过git init命令把这个目录变成Git可以管理的仓库

  git init                                    仓库初始化

例如
在这里插入图片描述

ls -ah              //查看隐藏目录       .git为隐藏目录

可以发现当前目录下多了一个.git的目录,这个目录是Git来跟踪管理版本库的

  vim   readme.txt                        //编写一个readme.txt文件

第三步:现在我们编写一个readme.txt文件,内容如下:

 I   like study   Linux
    what about you    

一定要放到wenjian目录下(子目录也行),因为这是一个Git仓库

第四步:把文件放到Git仓库 需要两个步骤
①用命令git add告诉Git,把文件添加到仓库:

  $ git add readme.txt
    git add 可以一次提交好几个文件  
    例如  git add 1.txt 2.txt 3.txt     

②用命令git commit告诉Git,把文件提交到仓库:

    $ git commit -m "wrote a readme file"
[master (root-commit) eaadf4e] wrote a readme file
 1 file changed, 2 insertions(+)
 create mode 100644 readme.txt

-m后面输入的是本次提交的说明,可以输入任意内容,必须写,因外这样对自己和对别人阅读都很重要。

至此,我们要讲的Git基本指令已经告一段落。有想学习更多指令的同学可以自行百度,网上的资料很多

2.Git从本地仓库上传文件到GitHub

第一步:创建SSH Key。
在用户主目录下,看看有没有.ssh目录,如果有,再看看这个目录下有没有id_rsa和id_rsa.pub这两个文件,如果已经有了,可直接跳到下一步。如果没有,打开Shell(Windows下打开Git Bash),创建SSH Key:

$ ssh-keygen -t rsa -C "youremail@example.com"

把引号里面的东西换成你的邮件地址
在用户主目录里找到.ssh目录,里面有id_rsa和id_rsa.pub两个文件,这两个就是SSH Key的秘钥对,id_rsa是私钥,不能泄露出去,id_rsa.pub是公钥,可以放心地告诉任何人。

第二步:登录GitHub

要将我们的文件从本地仓库上传到GitHub,我们就要创建一个GitHub账号(推荐使用谷歌浏览器)有了自己的账号以后,就可以进行登录,
登录成功后,打开“Account settings”,“SSH Keys”页面:
然后,点“Add SSH Key”,填上任意Title,在Key文本框里粘贴id_rsa.pub文件的内容:

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

点“Add Key”,你就应该看到已经添加的Key:如图

在这里插入图片描述

第三步:添加远程库
1.首先,创建一个新的仓库
在③填入名字(可任意,如过GitHub的仓库名与你本地的仓库名不一致,在把本地文件上传到GitHub时,系统会在GitHub上自动创建与你本地仓库相同的目录名),其他保持默认设置
在这里插入图片描述

2.在最下方点击“Create repository”按钮,就成功地创建了一个新的Git仓库:如下图所示。
在这里插入图片描述

我们把一个已有的本地仓库与之关联,然后,把本地仓库的内容推送到GitHub仓库。

第四步:在本地的仓库下运行命令:

(本地仓库也就是一开始咋们创建的版本库,如果忘记,可以自行返回第一层目录观看)

 git remote add origin git@github.com:zzyroot/wenjian.git

我的GitHub为zzyroot 这里把zzyroot改成你的GitHub用户名
我的本地仓库为wenjian 把这个改为你自己的本地仓库名

添加后,远程库的名字就是origin,这是Git默认的叫法,也可以改成别的,但是origin这个名字一看就知道是远程库。

下一步,先通过

 $ git add 
 $ git commit -m "wrote a readme file"

命令把文件放到仓库里。(如果已经添加过可以忽略,不懂可以看上面的Git基本操作指令)
再通过命令

$ git push origin master

就可以把本地库的所有内容推送到远程库上:

$ git push -u origin master
Counting objects: 20, done.
Delta compression using up to 4 threads.
Compressing objects: 100% (15/15), done.
Writing objects: 100% (20/20), 1.64 KiB | 560.00 KiB/s, done.
Total 20 (delta 5), reused 0 (delta 0)
remote: Resolving deltas: 100% (5/5), done.
To github.com:michaelliao/learngit.git
 * [new branch]      master -> master
Branch 'master' set up to track remote branch 'master' from 'origin'.

到这里我们的Git从本地仓库上传文件到GitHub就已经完成了

注意:

把本地库的内容推送到远程,用git push命令,实际上是把当前分支master推送到远程。
由于远程库是空的,我们第一次推送master分支时,加上了-u参数,Git不但会把本地的master分支内容推送的远程新的master分支,还会把本地的master分支和远程的master分支关联起来,在以后的推送或者拉取时就可以简化命令。

SSH警告
当你第一次使用Git的clone或者push命令连接GitHub时,会得到一个警告:
The authenticity of host ‘github.com (xx.xx.xx.xx)’ can’t be established.
RSA key fingerprint is xx.xx.xx.xx.xx.
Are you sure you want to continue connecting (yes/no)?
这是因为Git使用SSH连接,输入yes回车即可。

3.Git克隆

使用来源于需求,由于GitHub是一个开源软件。我们在上面浏览时,有时会发现一些对我们很有用的源代码或者文件。这个时候Git克隆就配上了用场。

3.1Git克隆远程项目到本地(克隆整个目录)

第一步:在主机进入到我们要克隆到的目录下

第二步:打开github,最上方会有一个搜索框,在里面输入我们要搜索的东西
在这里插入图片描述
第三步:在GitHub中找到别人的项目路径,复制。
在这里插入图片描述

第四步:输入 git clone 复制的链接
例如我的为

   git clone https://github.com/zzyroot/wenjian.git

这样,我们的克隆整个目录就完成了。

3.2 Git克隆指定文件到本地

第一步:在主机先进入到你要存放的路径
我的为

   cd /home/ubuntu/wenjian

第二步:在主机连接远程仓库GitHub(如果已经创建好,第二步可以忽略)

创建一个空的本地仓库(记住,需要重新创一个本地仓库,老手可以忽略)
在主机输入

  $ git init   

连接远程仓库GitHub(使用http)
在主机输入

$ git remote add -f origin https://github.com/文件路径

$ git remote add -f origin https://github.com/zzyroot/wenjian.git

第三步: 开启sparse checkout 模式
在主机输入

$ git config core.sparsecheckout true

第四步:设置过滤
在主机输入

echo 你要下载的文件
 >> .git/info/sparse-checkout  # 引号里边的为你要下载的单个文件名称

如:

echo  test.txt  >> .git/info/sparse-checkout  # 引号里边的为你要下载的单个文件名称

第五步:更新仓库
在主机输入

git pull origin master 

注意:
如果出现了这个错误,有可能是自己丢了东西或者文件名不对还有多了点引号什么的(本人在Linux上测试发现出来这个错误的原因是自己在echo后面的文件名两边加了双引号导致出现这样的错误。)

error: Sparse checkout leaves no entry on working directory

到这里就结束了,有不懂的地方或有错误的地方请大家及时反映,以方便更多人观看。

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值