Git win与linux换行符转换的问题

转载:warning: in the working copy of 'package-lock.json', LF will be replaced by CRLF the next time Git_warning: in the working copy of 'package.json', lf-CSDN博客

warning: in the working copy of 'package-lock.json', LF will be replaced by CRLF the next time Git

换行符的问题,Windows下换行符和Unix下的换行符不一样,git会自动转换,但是这样有问题,所以解决方法如下:

使用命令,禁止自动转换:

复制代码
git config --global core.autocrlf false

1.问题引入

windows平台进行 git add 时,控制台打印警告warning: in the working copy of 'XXX.py', LF will be replaced by CRLF the next time Git touches it

2.问题分析

Dos/Windows平台默认换行符:回车(CR)+换行(LF),即'\r\n'

Mac/Linux平台默认换行符:换行(LF),即'\n'

企业服务器一般都是Linux系统进行管理,所以会有替换换行符的需求

3.解决方案

  • 方案一:

    #提交时转换为LF,检出时转换为CRLF
    git config --global core.autocrlf true

*适用于Windows系统,且一般为Windows默认设置,会在提交时对换行符进行CRLF - LF的转换,检出时又会进行LF - CRLF的转换。

  • 方案二:

    #提交时转换为LF,检出时不转换
    git config --global core.autocrlf input

*适用于Linux系统,所有换行符都会进行CRLF - LF转换,但操作时不会转换回CRLF。

  • 方案三:

    #提交检出均不转换
    git config --global core.autocrlf false

*适用于Windows系统,且只在Windows上开发的情况。在提交、检出时不会对CRLF/LF换行符进行转换

文件提交时进行safecrlf检查:

复制代码
#拒绝提交包含混合换行符的文件
git config --global core.safecrlf true

#允许提交包含混合换行符的文件
git config --global core.safecrlf false

#提交包含混合换行符的文件时给出警告
git config --global core.safecrlf warn

4、问题思考

跨平台文件都有兼容性的问题,为什么只有core.autocrlf参数设置true检出时,会有LF-CRLF的转换?

有看到跨平台文件的问题:

· Linux文件在Windows下会显示成一行。

· Windows文件在Linux下结尾可能多出^M符号

那么就有以下可能性:

① Windows因为可视化界面较好,操作简易,且文件格式对日常操作没有较大影响,所以不做该功能。

② Git的pull等功能将文件拉取到本地时,都会基于检出配置进行操作,所以只要把core.autocrlf设置成true就好了。

相关推荐
skywalk81639 小时前
为一个库设置多个远程更新站用于git push,比如gitcode github等
git·github·gitcode
雪碧聊技术9 小时前
银河麒麟安装git
git
_OP_CHEN9 小时前
【Git原理与使用】(一)告别文件混乱!Git 初识:从版本灾难到高效管理的终极方案
linux·运维·git·github·运维开发·版本控制·企业级组件
装不满的克莱因瓶9 小时前
【Java架构 搭建环境篇三】Linux安装Git详细教程
java·linux·运维·服务器·git·架构·centos
0 0 09 小时前
git,github使用&快速上手指南
git·github
jimy111 小时前
git一键push的脚本
git
好好研究12 小时前
Git命令
大数据·git·elasticsearch
The Chosen One98514 小时前
【Linux】制作进度条小程序、git入门 (add、commit、push三板斧)以及git的其他问题
linux·运维·git
成为你的宁宁14 小时前
【Jenkins 参数化构建实战指南:基于机器环境与插件配置,详解 tag 标签管理、commit 修订号应用、版本切换及回退全流程】
git·gitlab·jenkins·参数化构建
ganshenml1 天前
【GIT】Git 本地无法识别远程分支的原因与解决方法 not a valid ref
大数据·git·elasticsearch