git rename后查看之前的记录

对于某个文件进行rename之后,使用show log命令查看之前的修改记录都会丢失,通过命令行方式进行mv之后,在tortoisegit中查看记录还是丢失的

git mv 从博客园下载已发布的文章.bat 博客园-下载已发布文章.bat
git commit -m "rename"
git push

解决办法:

今天在tortoisegit中无意中找到办法,对于重命名的文件,在日志信息界面中,选中有更名文件点右键有个选项"显示重命名或复制前日志",就可以查看到rename之前的所有日志。

在totorisegit中无法对某个文件进行目录移动而保留之前的提交记录,比如从A文件夹移动到B文件夹中

以上两项操作都会使用.git目录越来越大

git还原某个错误的push

有一次操作出错,导致把分支所有的提交都push到master中了,主要是这两个分支的代码差别还是非常大的

我的操作方法:

在tortoise中显示日志,还原到某个版本,然后重新push

目前这个操作还有点蒙,经过几番操作才正确撤消我的push

tortoisegit同步分支的某个提交到master

  1. 把master拉取到最新
  2. show log - 在log中选择已提交的分支,并选中要的那条提交记录
  3. 右键选择 摘取此提交,进行合并
  4. 在本地右键-同步,就可以把这个提交同步到master远程

Cherry Pick this Commint翻译为中文:摘取此提交

注意:不要使用右键的合并功能,它差不像tortoisesvn那样可以合并某个提交,而是要使用上述方法

需要图文的可以查看这篇《合并单个commit到指定分支上——tortoisegit cherry pick 的使用

修改文件日期为git的提交日期

出于我有一个需求,当我在家里的电脑上从git同步我的博客md文件时,新文件的日期是我拉取那天的日期,而当我想按日期排序文件时,很多文件并不能按我在git提交的时间来排序。

通过google查找到某些命令,这条在windows下对于英文命名的文件是可以查询到的,而对于中文命名的文件则会显示乱码,且不会显示日期。

git ls-tree -r --name-only HEAD | ForEach-Object { "$(git log -1 --format="%ai" -- "$_")`t$_" }

于是我就尝试从下面这几个方向解决我的问题

.NET 操作git

可使用的库:LibGit2Sharp

参考资料:

写了一些测试代码后放弃了,因为用.net来操作git比较麻烦

git 命令行

在我的电脑上,打开的git命令行是使用这个工具mingw

[](file:///C:/Users/qing/AppData/Local/Temp/OpenLiveWriter674401182/supfiles40FD0489/image[2].png)

mingw是Minimalist GNUfor Windows的缩写,允许控制台模式的程序使用微软的标准C运行时(C Runtime)库(MSVCRT.DLL),又可以调用windows的API

GNU是一个自由的操作系统,其内容软件完全以GPL方式发布。这个操作系统是GNU计划的主要目标,名称来自GNU's Not Unix!的递归缩写,因为GNU的设计类似Unix,但它不包含具著作权的Unix代码。GNU的创始人,理查德·马修·斯托曼,将GNU视为“达成社会目的技术方法”。

python脚本

目前我是使用gitpython操作git,安装命令: pip install gitpython

我测试此方法不能直接拿来使用:通过Python获取最后一次提交Git存储库文件的时间?

最后自己手写python脚本来解决这个问题,开源地址: 修改文件日期为git提交时间.py

关于git的几点疑问的更多相关文章

  1. Git复习(十)之常见报错和疑问

    报错 情况一:git pull报错 There is no tracking information for the current branch. Please specify which bran ...

  2. git远程易错点

    git pull下来用git branch -r查看远程分支才有数据 解决方案:指定当前工作目录工作分支,跟远程的仓库,分支之间的链接关系. 比如我们设置master对应远程仓库的master分支 g ...

  3. git远程从入门到放弃

    git pull下来用git branch -r查看远程分支才有数据 解决方案:指定当前工作目录工作分支,跟远程的仓库,分支之间的链接关系. 比如我们设置master对应远程仓库的master分支 g ...

  4. Git master branch has no upstream branch的解决

    Git master branch has no upstream branch的解决 在push代码时,出现“git master branch has no upstream branch”问题的 ...

  5. git推送代码报错:fatal: The current branch master has no upstream branch. To push the current branch and set the remote as upstream

    情景再现 远程新建仓库,然后本地 git bash执行以下代码 git init git add . git commit -m 'xxx' git remote add origin https:/ ...

  6. js生成二维码/html2canvas生成屏幕截图

    1.需求简述 (1) 最初需求: 根据后台接口获取url,生成一个二维码,用户可以长按保存为图片.(这时的二维码只是纯黑白像素构成的二维码) 方案1: 使用jquery.qrcode.min.js插件 ...

  7. no git binary found in $path(已解决,但是还有疑问)

    跟同行研究个项目代码,他把代码打包发我后,我解压到本地,路径和我本地个人项目路径基本相同, 但是当执行npm install时,就报了 no git binary found in $path ,这个 ...

  8. Git 使用疑问

    1)  fatal: remote origin already exists. 解决办法 ..$ git remote add origin git@git.*.com:tang/comment_s ...

  9. Git使用疑问

    1.git操作是出现Username for 'https://github.com':的验证问题 Username for 'https://github.com': 输入的是github上的邮箱账 ...

  10. 多本地代码工作点更新到2个远端GIT仓库

    摘要:本文介绍了笔者多个本地工作节点(地方)的多台电脑(PC/笔记本电脑)同步源码到2个远端的GIT(一个GITHUB国外强制公开,一个oschina国内可不公开). 作者:太初 转载说明:请指明原作 ...

随机推荐

  1. Python 读取图片 转 base64 并生成 JSON

    Python 读取图片 转 base64 并生成 JSON import json import base64 img_path = r'D:\OpenSource\PaddlePaddle\Padd ...

  2. Linux 堡垒机命令行中如何上传下载文件(SecureCRT - SFTP)

    通过堡垒机进入的 Linux 操作系统,无法直接使用 WinSCP 等工具进行文件的上传下载. 可使用 SecureCRT 先进入命令行模式 配置 配置 Linux 堡垒机的连接方式 连接 选择要进入 ...

  3. Docker 启动失败 (code=exited, status=1/FAILURE)错误解决办法

    ob for docker.service failed because the control process exited with error code. See "systemctl ...

  4. SpringBoot Docker 发布

    本文是手动模式,可以移步 Intellij IDEA 集成 Docker 发布 使用 Intellij 集成Docker 发布,比较方便 pom 文件 <groupId>com.vipso ...

  5. websever

    1 在浏览器键入url,按下回车会经历如下行为 浏览器向 DNS 服务器请求解析该 URL 中的域名所对应的 IP 地址; 解析出 IP 地址后,根据该 IP 地址和默认端口 80,和服务器建立 TC ...

  6. @Scheduled cron 定时任务表达式含义,及* ?的区别

    好多网友对@Scheduled cron表达式含义做了阐述,个人认为很多对于 * ?的说明不够具体也不算准确,借此本文特别对 * ?做一下说明. cron格式:[秒数][分钟][小时][日期][月份] ...

  7. C++岗位面试真题宝典 -- 操作系统篇

    2.1 Linux中查看进程运行状态的指令.查看内存使用情况的指令.tar解压文件的参数. 参考回答 查看进程运行状态的指令:ps命令."ps -aux | grep PID",用 ...

  8. JSP 学习笔记 | 一、JSP 原理理解

    前文:IDEA | 使用Maven创建Web项目并配置Tomcat JSP(全称:Java Server Pages):Java 服务端页面.是一种动态的网页技术,其中既可以定义 HTML.JS.CS ...

  9. POJ 1236 Network of Schools (连通图 - Garbow 算法)

    POJ 1236 Network of Schools ​ 校园网:给定N所学校和网络,目标是分发软件其他学校都可收到,求①所需最少分发学校数:②若任选学校都能收到,最低新增边数. 思路:同一个强连通 ...

  10. spring管理实务有几种方式

    一:事务认识 大家所了解的事务Transaction,它是一些列严密操作动作,要么都操作完成,要么都回滚撤销.Spring事务管理基于底层数据库本身的事务处理机制.数据库事务的基础,是掌握Spring ...