引言

在开发阶段,开发环境测完的配置文件(页面化管理)和shell脚本在上生产时,出现了字符和变量(变量从配置文件中获取)拼接缺失等莫名其妙的问题。

名称介绍

ASCII字符代码表

ASCII码

维基百科

CR

维基百科CR

CR: Carriage Return,对应ASCII中的转义字符是\r,对应ASCII值是13,常用于Macintosh(早期的Mac OS)系统单个字符,

表示回车

LF

维基百科LF  

LF: Line Feed,对应ASCII中的转义字符是\n,对应ASCII值是10,常用于Unix/Linux/Mac OS X系统中单个字符,表示换行

CRLF

维基百科CRLF

CRLF: Carriage Return & Line Feed,对应ASCII中的转义字符是\r\n,常用于Window系统中两个字符,表示回车并换行

问题

shell脚本在不同系统使用问题

问题描述

Windows系统开发了某个shell脚本,默认是CRLF格式的,在转移到Linux系统上执行时,无法正常执行。

解决方案

方案一:使用notepad++

打开notepad++软件,显示符号

notepad++显示符号

或者

notepad++快捷键显示符号

替换所有CRLFLF

notepad++转换字符格式

或者

notepad++全局替换字符

方案二:使用Linux系统相关命令将文件转化为unix格式

一共有三种方式:

  • 使用dos2unix命令dos2unix file_name,前提是Linux安装了该命令功能。
  • 使用sed命令sed -i "s/\r//" file_name或者sed -i "s/^M//" file_name将回车字符删除掉。
  • 使用vi/vim命令,执行:set ff=unix将文件设置为unix格式文件。

shell脚本所获取的配置文件内容字符存在^M字符

问题描述

通过使用cat -A file_name的命令可以查看隐藏的字符,shell脚本所获取的配置文件内容字符存在^M字符,即存在\r回车字符。

存在^M字符

解决方案

在shell脚本对变量使用

key1=`echo $key1 | sed "s/\r//g"`

总结

名词 含义 ASCII字符 系统
CR Carriage Return,回车 \r Macintosh(早期的Mac OS)系统
LF Line Feed,换行 \n Unix/Linux/Mac OS X系统
CRLF Carriage Return & Line Feed`,回车并换行 \r\n Window系统