Github 上传、更新、删除项目以及修改commit

首先,得有个github账户,本次的博客是将如何在window端上传项目以及修改项目,以及我自己实践遇到的各种bug。

  • 建立和上传项目

step1:下载window对于版本的github客户端,网址是https://www.git-scm.com/download/,按照步骤和版本安装,安装过程可以参考:https://blog.csdn.net/weixin_41714277/article/details/79399270,安装成功后,在随意的文档鼠标右键可以看到,Git GUI和Git Bash 说明安装成功,如图1。第一次使用git的同学,需要链接自己的github的账户和密码,配置ssh key提供对服务器读写操作的权限。

图1

  •  配置git账户过程

  • step1-1:进入电脑C盘用户所在存放文件的区域,如下图2所示,在该目录下也就是空白的地方,右键选择git bash here

图2

step1-2:随即弹出命令框,输入$ ssh-keygen -t rsa -C “github注册邮箱”,之后会要求确认路径和输入密码,默认的一路回车就行。成功的话会在~/下生成.ssh文件夹 。如图2所示的.ssh文件夹,图3为命令框

图3

  • step1-3:进入 .ssh文件夹,公钥id_rsa.pub的内容复制,我的打开方式是sublime,要看看会不会出现乱码

  • step1-4:然后进入网页版的github账号中,如图4所示,点击Settings,进入页面设置。页面如图5所示,进入左边栏的“SSH and GPG keys”选项,建立新的ssh key链接,可以建立多个,点击右上角“New SSH Key"选项。点击之后,进入页面,如图6所示,title就是对这个key自己起的名字,Key就是刚刚在 .ssh文件夹中公钥id_rsa.pub的内容,点击最后Add 添加即可。配置成功。

图4

图5

图6

 

step1-5:最后,然后配置一下git用户和email,任意位置右键 git bash here,弹出命令框,输入 
  git config –global user.name “git账户名字”
  git config –global user.email “git注册邮箱”

配置全部都做完了,就可以开始同步项目!
 

step2:开始创建新的的项目,在网页github右上角选择New repository创建项目,如图7所示操作,输入项目名称,确认创建项目。如果不想要或者错建想要删除项目,找到该项目进入,选择项目中的settings,然后页面滑到最下方有个选项“Delete this repository”,点击输入项目名称,则可确认删除。

图7

step3:此时创建项目为空,需要从本地上传文件或者代码。进入上传项目的目录,在空白处右键选择Git Bash Here,弹出命令框。上传过程主要分5步走,分别是

  • step3-1:git init

执行完后,再当前文件夹下生成一个.git配置,看不见的话可能是系统隐藏文件,显示隐藏的文件夹如下图所示,在文件栏选择“查看”,然后勾选“隐藏的项目”即可。

  • step3-2:git add 文件名 

将选择的文件存进了缓存流,还未发送

  • step3-3:git commit -m “给上传文件的备注、提示之类”

commit是对文件提交,存进了缓存流的发送头,准备发送

  • step3-4:git remote add origin 对应的项目文件夹的网址

这步绑定了这个.git配置文件夹对应的远端服务器的发布路径 ,网址可以在进入网页版的项目,点击右边的“Clone or download”然后复制路径网址信息

  • step3-5:git push -u origin master

这一步是发送上传到服务器,如果是下面a图的显示,那就是上传成功会有进度条的显示,但是往往是不成功,原因是里面有些更新以及readme的文件没有同步到本的项目中去,会出现如b图所示的页面,拯救的办法就是

  • 在输入step3-5的语句之前,输入 git pull --rebase origin master

此命令目的是先将两边同步之后才进行传输

a图

b图

这样就大功告成,刷新下网页,看看自己的github项目是否已经成功上传文件即可。上传文件还要注意的是github上传文件限制了100.00MB以内,超过50.00MB小于100.00MB会进行warning,超过100.00MB会进行error错误,如果上传大型数据集需要注意查找上传大文件的方式,因为没有报错,所以我也没尝试。

  • 修改项目文件

除了上传项目文件,当本地的文件进行了修改,希望服务端的项目文件也进行更新的时候,就需要修改项目文件了。更新修改也是对git项目查看的过程。

step1:git status

查看当前的状态,会出现几种可能的情况

  • 情况1:目前工作目录相当干净。所有已跟踪文件在上次提交后都未被更改过。 当前目录下没有出现任何处于未跟踪状态的新文件,否则 Git 会在这里列出来。 同时显示了当前所在分支,该分支同远程服务器上对应的分支没有偏离。 分支名是 “master”,这是默认的分支名。 

情况2:在Changes not staged for commit 这行下面显示了本地已经进行更新的文件,文件的内容发生了变化,但还没有放到暂存区。 要暂存这次更新,要运行 “git add" 命令。 运行git add之后再用git status查看就会发生相应的变化。

git add:可以用它开始跟踪新文件,或者把已跟踪的文件放到暂存区,还能用于合并时把有冲突的文件标记为已解决状态等。 将这个命令理解为“添加内容到下一次提交中”而不是“将一个文件添加到项目中”要更加合适。

 

  • 情况3:Changes to be committed 这行下面显示了已暂存状态的文件。说明通过git add我们将文件放到了暂存区了,如果要使仓库中的文件进行更新还需要提交,使用"git commit -m "修改文件的commit备注、注释"”就可以进行提交,放到发送头,但是还需要进行发送才能更新到仓库中,接下来按照上面【建立和上传项目】的【step3-5】执行即可。

这样就可以完成更新,上自己的github项目查看即可。

  • 修改commit的备注信息

在git push 之后还想要修改commit的信息,需要用到命令git rebase -i HEAD实现

step1:git log查看提交的commit,找到你要更改的commit是第几条(这一步如果仓库中文件少也可以不用) 

step2:输入git rebase -i HEAD~n,其中n是数字,表示查看倒数第几个commit进入其文件进行修改,一般要小于文件个数。然后会进入commit设置文件,对文件中开始的每个commit对应的pick(其中显示的是你要更改的那个commit的编号),将pick更改为edit,然后保存退出,所有的操作按照vim操作进行即可,:wq

step3:git commit –amend;表示对commit重新进行修改,输入 git commit -m “修改注释信息”

step4:git rebase –continue

step5:git push -f,按照以上输入便可以到项目中看commit是否修改,记得刷新。

 

  • git项目中readme的编辑

按照下面博客的规则编辑即可,也比较全面了https://blog.csdn.net/kaitiren/article/details/38513715

主要的在于标题,采用###实现,注意###与正文之家加空格隔开,链接采用[链接文字](网址)实现即可,然后插入图片的话需要将图片打包为image文件,上传到仓库上,然后再进行调用,具体写法如下。代码段的插入采用数字1旁边的符号``` code```实现。

![Image text](https://github.com/账户名称/项目名称/raw/master/Image文件夹/图片名称.png)
![Image text]:当图片不存在时显示文字
此链接由三部分组成
第一:https://github.com/   固定写法
第二:用户名/仓库名
第三:raw/master/     固定写法   原生管理
第四:仓库名下的存放图片的文件目录+图片名称

 

 

  • 删除git项目中文件

可以参考博客 https://blog.csdn.net/weixin_42350212/article/details/80560272

 

  • 使用git中遇到的一些问题

  • 问题1:Aborting commit due to empty commit message.

原因是只是进行git commit,但是没有填写coomit的相关信息,需要将git commit改为 git commit -m “注释信息”即可

  • 问题2: error: failed to push some refs to '……'

原因是在进行push上传到仓库的时候,仓库和本地没有进行同步,所以先要pull 进行同步之后,push才能成功

  • 问题3:error: The following untracked working tree files would be overwritten by checkout

原因是上传的文件重复或者缓存区有遗留的文件需要清理或者一些untracked working tree files,清理之后才能进行操作

进入本地仓库的路径下执行git clean -d -fx清楚一些导致出错的文件

 git clean 参数 

    -n 显示将要删除的文件和目录;

    -x -----删除忽略文件已经对git来说不识别的文件

    -d -----删除未被添加到git的路径中的文件

    -f -----强制运行

    git clean -n

    git clean -df

    git clean -f

 

在我学习使用github建立和管理项目过程中,感谢这些博主的帮助:

https://git-scm.com/book/zh/v2/Git-基础-记录每次更新到仓库(git使用说明书)

git中一些常用命令:https://www.cnblogs.com/imyalost/p/9259149.html

https://blog.csdn.net/crazydony/article/details/51983343

 

  • 8
    点赞
  • 24
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值