换行符‘\n’和回车符‘\r’
顾名思义,换行符就是另起一行,回车符就是回到一行的开头,所以我们平时编写文件的回车符应该确切来说叫做回车换行符
'\n' 10(0x0a) 换行(newline)
'\r' 13(0x0d) 回车(return)
也可以表示为'\x0a'和'\x0d'.(16进制)
在windows系统下,回车换行符号是"\r\n".但是在Linux等系统下是没有"\r"符号的。
在解析文本或其他格式的文件内容时,常常要碰到判定回车换行的地方,这个时候就要注意既要判定"\r\n"又要判定"\n"。
写程序时可能得到一行,将其进行trim掉'\r',这样能得到你所需要的string了。
===============================================
1. 写程序时,代码里面都是'\n'表示换行。
2. 对于文件里的换行,
(1)Windows系统里,文件每行结尾是"<回车><换行>""\r\n"
(2)Mac系统里, 文件每行结尾是"<回车>",即'\r'
(3)Unix系统里, 文件每行结尾是"<换行>",即'\n'
所以,用'\n'作为作为换行符的文件,用Windows的记事本打开时 会没有换行;
而用"\r\n"作为换行符的文件(windows文件),用Linux或mac的vim打开时 会将\r显示成^M。
Mac的zsh中,采用\n作为换行符,遇到\r将会被解释为回车符,即移动到该行的行首,然后继续执行代码。
在Linux中执行.sh脚本,异常/bin/sh^M: bad interpreter: No such file or directory。
分析:这是不同系统编码格式引起的:在windows系统中编辑的.sh文件可能有不可见字符,所以在Linux系统下执行会报以上异常信息。
解决:
1)在windows下转换:
利用一些编辑器如UltraEdit或EditPlus等工具先将脚本编码转换,再放到Linux中执行。转换方式如下(UltraEdit):File-->Conversions-->DOS->UNIX即可。
2)也可在Linux中转换:
首先要确保文件有可执行权限 #sh>chmod a+x filename
然后修改文件格式 #sh>vi filename
利用如下命令查看文件格式 :set ff 或 :set fileformat
可以看到如下信息 fileformat=dos 或 fileformat=unix
利用如下命令修改文件格式 :set ff=unix 或 :set fileformat=unix{set ff=unix 【fileformat】}
:wq (存盘退出)
最后再执行文件 #sh>./filename
what’s meaning of “configure: error: cannot run /bin/sh config/config.sub”
编一个东西的时候
执行./configure的时候出的错
“configure: error: cannot run /bin/sh config/config.sub”
结果发现是系统没有装libtool的缘,然后再./configure则没有这个问题了
#include
#include
using namespace std;
/* 删除字符串行首/行尾的字符 */
int main(void)
{
string s = "\r\n\t 是\t这是随便写的一句话。\t\t ";
size_t n = s.find_last_not_of(" \r\n\t");
if(n != string::npos)
{
s.erase( n + 1 , s.size() - n );
}
n = s.find_first_not_of ( " \r\n\t" );
if(n != string::npos)
{
s.erase( 0 , n );
}
cout << s << endl;
}
➜ test g++ test.cpp
➜ test ./a.out
是 这是随便写的一句话
给大家推荐一个站点:http://stackoverflow.com/
今天用macvim打开同事写的一个文件,代码变成只有一行了,在原来的换行后面多了^M。
查到这个是因为dos换行符在我这边不支持,于是替换^M为mac这边的换行符,
在vim编辑模式下输入:
:%s/^M/\r/g ;^M由ctrl+V+M获得
这样会替换掉所有的^M为换行,再保存文件就ok