当我在 Unix 环境中运行特定的 SQL 脚本时,我在 SQL 脚本的每一行末尾看到一个“^M”字符,因为它回显到命令行。我不知道 SQL 脚本最初是在哪个操作系统上创建的。
是什么原因造成的,我该如何解决?
当我在 Unix 环境中运行特定的 SQL 脚本时,我在 SQL 脚本的每一行末尾看到一个“^M”字符,因为它回显到命令行。我不知道 SQL 脚本最初是在哪个操作系统上创建的。
是什么原因造成的,我该如何解决?
它是由 DOS/Windows 行尾字符引起的。正如 Andy Whitfield 所说,Unix 命令 dos2unix 将有助于解决问题。如果您想了解更多信息,可以阅读该命令的手册页。
vi
通过运行以下命令修复行结尾:
:set fileformat=unix
:w
最简单的方法是使用vi
. 我知道这听起来很糟糕,但它很简单并且已经安装在大多数 UNIX 环境中。^M 是 Windows/DOS 环境中的一个新行。
从命令提示符:$ vi filename
然后按“ :
”进入命令模式。
全局搜索和替换所有内容是:%s/^M//g
“按住控制然后按 V 然后按 M ”,这将替换 ^M 什么都没有。
然后写入并退出输入“ :wq
”完成!
尝试使用 dos2unix 去除 ^M。
在 vi 中,执行:%s/^M//g
要获得^M
按住CTRL键,请按Vthen M(同时按住 control 键),^M
将出现 。这将找到所有事件并将它们替换为空。
SQL 脚本最初是在 Windows 操作系统上创建的。'^M' 字符是由于 Windows 和 Unix 对行尾字符的使用有不同的想法。您可以在命令行中使用 perl 来解决此问题。
perl -pie 's/\r//g' filename.txt
^M 通常是由 Windows 运算符换行符引起的,翻译成 Unix 看起来像 ^M。命令 dos2unix 应该很好地删除它们
dos2unix [选项] [-c convmode] [-o file ...] [-n infile outfile ...]
C:\tmp\text>dos2unix hello.txt helloUNIX.txt
如果没有安装 dos2unix,Sed 的使用范围更广,也可以做这种事情
C:\tmp\text>sed s/\r// hello.txt > helloUNIX.txt
你也可以试试 tr:
cat hello.txt | tr -d \r > helloUNIX2.txt
结果如下:
C:\tmp\text>dumphex hello.txt
00000000h: 48 61 68 61 0D 0A 68 61 68 61 0D 0A 68 61 68 61 Haha..haha..haha
00000010h: 0D 0A 0D 0A 68 61 68 61 0D 0A ....haha..
C:\tmp\text>dumphex helloUNIX.txt
00000000h: 48 61 68 61 0A 68 61 68 61 0A 68 61 68 61 0A 0A Haha.haha.haha..
00000010h: 68 61 68 61 0A haha.
C:\tmp\text>dumphex helloUNIX2.txt
00000000h: 48 61 68 61 0A 68 61 68 61 0A 68 61 68 61 0A 0A Haha.haha.haha..
00000010h: 68 61 68 61 0A haha.
要在 vi 编辑器中替换 ^M 字符,请使用以下命令
打开文本文件说 t1.txt
vi t1.txt
按 进入命令模式shift + :
然后按提到的键%s/^M/\r/g
in above ^M is not (shift + 6)M instead it is (ctrl + V)(ctrl + M)
命令的替代方法dos2unix
是使用标准实用程序,例如sed
.
例如,对 unix 的 dos:
sed 's/\r$//' dos.txt > unix.txt
unix到dos:
sed 's/$/\r/' unix.txt > dos.txt
您可以通过 sed 命令直接从文件中删除 ^M,例如:
sed -i'.bak' s/\r//g *.*
如果您对更改感到满意,请删除 .bak 文件:
rm -v *.bak
使用 tr 将 DOS/Windows (\r\n) 行尾转换为 Unix (\n) 行尾:
tr '\r\n' '\n' < dosFile.txt > unixFile.txt
od -a $file
对于在 Linux 上探索这些类型的问题很有用(类似于上面的 dumphex)。
在 Perl 中,如果你不想设置 $/ 变量并使用 chomp() 你也可以这样做:
$var =~ /\r\n//g;
我的两分钱
如前所述,Windows 程序喜欢用 CRLF 终止行,即代替\r\n
Unix/Linux 标准\n
。由于我不需要所有功能,dos2unix
因此我通过将以下内容添加到 my 来替换它,~/.bashrc
从而删除\r
:
function win2unix() {
tmp=$(mktemp) && tr -d '\r' < $1 > $tmp && mv $tmp $1
}
现在,当我想摆脱^M
创建的那些字符时,例如当我从 Excel 或 Calc 导出 CSV 文件时,我可以执行以下操作:
win2unix filename.csv
当然,您也可以使用sed
或其他东西。顺便说一句,我用cat -e $filename
形象化的^M
结局。
另一个可行的 vi 命令::%s/.$//
这会删除文件中每一行的最后一个字符。这个搜索和替换命令的缺点是它不关心最后一个字符是什么,所以注意不要调用它两次。