您好,欢迎来到三六零分类信息网!老站,搜索引擎当天收录,欢迎发信息

Unix/Dos 文本文件格式_MySQL

2025/8/25 12:23:37发布35次查看
折腾了一两个小时,有一批文本文件总是没办法导进数据库里面,用notepad++另存后则ok。
后来发现这批文本文件都是unix 格式。没注意检查文件格式。。。。。
在linux中,文本文件用/n表示回车换行,而windows用/r/n表示回车换行。
------------------------------------------------------------------------------------------
linux与windows文本格式之间的转化
原理:
在linux中,文本文件用/n表示回车换行,而windows用/r/n表示回车换行。所以在linux中使用windows的文本文件常常会出现错误
因为装了双系统,所以有时一些文件在两个系统之间共享,不过之前一直没有很在意这个问题.在windows系统中用word或者notepad++打开文件,在linux系统中一直用的是vim编辑器,不过昨天在命令行界面就只能用vi了..郁闷!! 中文支持都是个头痛的问题,在windows编辑过的文本文件每行末尾都会以^m以结尾...
----------------------------------------------------
linux提供了两种文本格式相互转化的命令:dos2unix和unix2dos,dos2unix把/r/n转化成/n,unix2dos把/n转化成/r/n。
ubuntu 7.10中默认没有dos2unix或者unix2dos
提示要安装tofrodos这个包( converts dos  unix text files, alias tofromdos )
$sudo apt-get install tofrodos
dos2unix --> 将windows文本文件转化为linux格式
unix2dos --> 将linux文本文件转化为windows格式
用法:
man dos2unix
man unix2dos
----------------------------------------------------
使用linux系统中自带的流文本编辑器sed
dos/windows和linux/unix的文件换行回车格式不同, 基于 dos/windows 的文本文件在每一行末尾有一个cr(回车)和lf(换行),而 unix 文本只有一个换行..
1. 把dos/windows下的文件移至linux/unix系统
虽然很多程序不在乎 dos/windows 格式的 cr/lf 文本文件,但是有几个程序却在乎 -- 最著名的是 bash,只要一遇到回车,它就会出问题。以下 sed 调用将把 dos/windows 格式的文本转换成可信赖的 unix 格式:
$ sed -e 's/.$//' mydos.txt > myunix.txt
该脚本的工作原理很简单:替代规则表达式与一行的最末字符匹配,而该字符恰好就是回车。我们用空字符替换它,从而将其从输出中彻底删除。如果使用该脚本并注意到已经删除了输出中每行的最末字符,那么,您就指定了已经是 unix 格式的文本文件。也就没必要那样做了!
2. 把linux/unix 文本移至 windows 系统,使用以下脚本执行必需的格式转换:
$ sed -e 's/$//r/' myunix.txt > mydos.txt
在该脚本中,'$' 规则表达式将与行的末尾匹配,而 '/r' 告诉 sed 在其之前插入一个回车。在换行之前插入回车,立即,每一行就以 cr/lf 结束。请注意,仅当使用 gnu sed 3.02.80 或以后的版本时,才会用 cr 替换 '/r'。
----------------------------------------------------
据说还可以用vim来处理(未测试):
在 vim 的命令模式中输入 :%s/^m$//g 后,回车即会自动删除该文件中的所有 ^m 字符
命令分析:
%指匹配整个文件, s是置换的意思, ^m 注意要用ctrl + v和ctrl + m来输入,m后面的$代表匹配行尾的内容(用空格替换), 最后的g则表示每行中匹配到的内容都要置换
----------------------------------------------------
使用tr 命令实现:
1. 使用类似于这样的表示法: tr abc xyz  ,它表示用字母“x”去替换出现的所有字母“a”,用字母“y”去替换所有字母“b”,用字母“z”去替换所有字母“c”。
2. tr a-z a-z 将用对应的大写字母来替换所有的小写字母(例如,它将“no smoking”转换成“no smoking”)。
3. 当您在 vi 编辑器中想强调正在编辑的文本的某一部分时,使用这一特殊技巧非常方便。只要按一下 escape 键,然后按 : 键,再输入 2,4!tr 'a-z' 'a-z' ,最后按一下 return 键。现在,从第 2 行到第 4 行的字母就都转换成了大写字母。
4. 另外,当有人给您发送了一个在 mac os 或 dos/windows 机器上创建的文本文件时,您会发现 tr 非常有用。如果没有将文件保存为使用 unix 换行符来表示行结束这种格式,则需要将这样的文件转换成本机 unix 格式,否则一些命令实用程序不会正确地处理这些文件。mac os 的行尾以回车字符结束,许多文本处理工具将这样的文件作为一行来处理。为了纠正这个问题,可以用下列技巧:
   * mac -> unix: tr '/r' '/n'  unixfile
   * unix -> mac: tr '/n' '/r'  macfile
----------------------------------------------------
tips:
回车”(carriage return)和“换行”(line feed)这两个概念的来历和区别。
          在计算机还没有出现之前,有一种叫做电传打字机(teletype model 33,linux/unix下的tty概念也来自于此)的玩意,每秒钟可以打10个字符。但是它有一个问题,就是打完一行换行的时候,要用去0.2秒,正好可以打两个字符。要是在这0.2秒里面,又有新的字符传过来,那么这个字符将丢失。
于是,研制人员想了个办法解决这个问题,就是在每行后面加两个表示结束的字符。一个叫做“回车”,告诉打字机把打印头定位在左边界;另一个叫做“换行”,告诉打字机把纸向下移一行。这就是“换行”和“回车”的来历,从它们的英语名字上也可以看出一二。
后来,计算机发明了,这两个概念也就被般到了计算机上。那时,存储器很贵,一些科学家认为在每行结尾加两个字符太浪费了,加一个就可以。于是,就出现了分歧。
unix系统里,每行结尾只有“”,即/n;windows系统里面,每行结尾是“”,即“/n/r”;mac系统里,每行结尾是“”,即/n;。一个直接后果是,unix/mac系统下的文件在 windows里打开的话,所有文字会变成一行;而windows里的文件在unix/mac下打开的话,在每行的结尾可能会多出一个^m符号。
该用户其它信息

VIP推荐

免费发布信息,免费发布B2B信息网站平台 - 三六零分类信息网 沪ICP备09012988号-2
企业名录 Product