northwest NW Charles Main 3.0 .98 3 34**VA** // 手动删除 ^M 以验证
western WE Sharon Gray 5.3 .97 5 23**VA** // 同上
southwest SW Lewis Dalsass 2.7 .8 2 18**VA** // 同上
southern SO Suan Chin 5.1 .95 4 15^M**VA** // 保留 ^M 以对比
southeast SE Patricia Hemenway 4.0 .7 4 17^M**VA** // 同上
eastern EA TB Savage 4.4 .84 5 20^M
northeast NE AM Main Jr. 5.1 .94 3 13^M
north NO Margot Weber 4.5 .89 5 9^M
central CT Ann Stephens 5.7 .94 5 13^M
保存推出后 cat file1, 屏幕显示如下:
northwest NW Charles Main 3.0 .98 3 34**VA**
western WE Sharon Gray 5.3 .97 5 23**VA**
southwest SW Lewis Dalsass 2.7 .8 2 18**VA**
**VA**rn SO Suan Chin 5.1 .95 4 15
**VA**ast SE Patricia Hemenway 4.0 .7 4 17
eastern EA TB Savage 4.4 .84 5 20
northeast NE AM Main Jr. 5.1 .94 3 13
north NO Margot Weber 4.5 .89 5 9
central CT Ann Stephens 5.7 .94 5 13
证明猜测正确,只是这个 ^M 是什么东西呢?
原因和解决方法:
Google 之,得说法如下:
Linux编辑器vim中删除行尾的^M
有时候,在 Linux 中使用打开曾在 Windows 中编辑过的文件时,会在行尾看到 ^M 字符。看起来总是感觉很别扭。
删除方法如下:
在 Vim 的命令模式中输入 :%s/^M$//g 后,回车即会自动删除该文件中的所有 ^M 字符。
注意: ^M 要用 Ctrl + v, Ctrl + m 来输入, 用键盘直接敲^和M是不行的! 后面的 $ 代表匹配行尾的内容,最后的 g 则表示每行中匹配到的内容都要置换--全局替换,否则只替换每行中匹配到的第一个。
又脚本删除方法:
cat file | col -b > file.1 // 这个可以去掉,但是生成文件里汉字变乱码(后一句据说)
sed -e 's/.$//g' file // 正确
sed ‘s/^M//' file // 正确,但是 ^M = Ctrl + v, Ctrl + m
诡异的是,这个 ^M 在文件第一次被修改之后才可见,之前同是用 vim 编辑打开,^M 不可见。
附录:^M 另一个会出现的情况是文件在 windows 和 Linux 系统间通过 Ftp 传送。这是建议方法是:强行设定 ftp 方式为 ascii 方式就可以了啊! 当然也可以通过软件 dos2unix 搞定。// 我没尝试过哈。
从现象到原因到解决方法如下。备份防遗忘。
Tue,Jan/26/2010