关于回车换行符

关于应用(转):

我一直没有搞得很清楚,回车和换行符有啥区别。
记得大一时,C语言老师就说过回车、换行,但都没说得那么细。前两天,看写两句Perl代码时,

忽然想起区别一下回车和换行(\r和\n)。现在理解清楚了,记个笔记吧。

符号    ASCII码      意义
\n        10        换行NL
\r        13        回车CR

回车 \r 本义是光标重新回到本行开头,r的英文return,控制字符可以写成CR,即Carriage Return
换行 \n 本义是光标往下一行(不一定到下一行行首),n的英文newline,控制字符可以写成LF,即Line Feed
在不同的操作系统这几个字符表现不同,比如在WIN系统下,这两个字符就是表现的本义,在UNIX类系统,换行\n就表现为光标下一行并回到行首,在MAC上,\r就表现为回到本行开头并往下一行,

至于ENTER键的定义是与操作系统有关的。通常用的Enter是两个加起来。

在计算机还没有出现之前,有一种叫做电传打字机(Teletype Model 33)的玩意,每秒钟可以打10个字符。但是它有一个问题,就是打完一行换行的时候,要用去0.2秒,正好可以打两个字符。要是在这0.2秒里面,又有新的字符传过来,那么这个字符将丢失。
于是,研制人员想了个办法解决这个问题,就是在每行后面加两个表示结束的字符。一个叫做“回车”,告诉打字机把打印头定位在左边界;另一个叫做“换行”,告诉打字机把纸向下移一行。
这就是“换行”和“回车”的来历,从它们的英语名字上也可以看出一二。
后来,计算机发明了,这两个概念也就被般到了计算机上。那时,存储器很贵,一些科学家认为在每行结尾加两个字符太浪费了,加一个就可以。于是,就出现了分歧。
 
/*======================================*/
\n:  UNIX 系统行末结束符
\n\r: window 系统行末结束符
\r:  MAC OS 系统行末结束符
/*======================================*/
一个直接后果是,Unix/Mac系统下的文件在Windows里打开的话,所有文字会变成一行;

而Windows里的文件在Unix/Mac下打开的话,在每行的结尾可能会多出一个^M符号。

(这也是经常说见到的现象,哈哈,原来是这样的)

 

 

关于oracle数据库:

oracle中去掉文本中的换行符、回车符、制表符小结
一、特殊符号ascii定义
 制表符 chr(9) 
 换行符 chr(10)
 回车符 chr(13)
二、嵌套使用repalce,注意每次只能提交一个符号,如先回车再换行
          select REPLACE(gg, chr(10), '') from dual
    要注意chr(13) | | chr(10) 此类结合使用的情况比较多,回车换行在notepad中是比较好看点的
,所以要考虑此种情况


 2、例子二
要注意chr(13) | | chr(10) 此类结合使用的情况比较多,回车换行在notepad中是比较好看点的,
所以要考虑此种情况

三、对于字符大对象的符号处理
    对于clob字段中的符号处理,先to_char然后一样的处理


2.2.1      单记录字符函数
        函     数                      说                明 
  ASCII                     返回对应字符的十进制值 
  CHR                       给出十进制返回字符 
 CONCAT                    拼接两个字符串,与  ||       相同 
  INITCAT                   将字符串的第一个字母变为大写 
  INSTR                     找出某个字符串的位置 
  INSTRB                    找出某个字符串的位置和字节数 
  LENGTH                    以字符给出字符串的长度 
  LENGTHB                   以字节给出字符串的长度 
  LOWER                     将字符串转换成小写 
  LPAD                      使用指定的字符在字符的左边填充 
  LTRIM                     在左边裁剪掉指定的字符 
  RPAD                      使用指定的字符在字符的右边填充 
  RTRIM                     在右边裁剪掉指定的字符 
  REPLACE                   执行字符串搜索和替换 
  SUBSTR                    取字符串的子串 
  SUBSTRB                   取字符串的子串(以字节) 
  SOUNDEX                   返回一个同音字符串 
  TRANSLATE                 执行字符串搜索和替换 
  TRIM                      裁剪掉前面或后面的字符串 
  UPPER                     将字符串变为大写 
  NVL                       以一个值来替换空值
ASCII(<c1>) 
<c1>是字符串。返回与指定的字符对应的十进制数。 
SQL> select ascii('A') A,ascii('a') a,ascii('0') zero,ascii(' ') space from dual;
     A      a  ZERO   SPACE 
---------- ---------- ---------- ---------- 
     65     97     48     32
SQL> select ascii('赵') zhao,length('赵') leng from dual;
      ZHAO        LENG 
    ----------  ---------- 
     54740         1
CHR(<I>[NCHAR]) 
给出整数,返回对应字符。如:
SQL> select chr(54740) zhao,chr(65) chr65 from dual;
ZH   C 
--  - 
赵  A
CONCAT(<c1>,<c2>) 
SQL> select concat('010-','8801 8159')||'转23' 赵元杰电话  from dual;
赵元杰电话
-----------------
010-8801 8159 转23
INITCAP(<c1>)
返回字符串c1       并第一个字母变为大写。例如:
SQL> select initcap('simth') upp from dual;
UPP 
----- 
Simth
INSTR(<c1>,<c2>[,<I>[,<j>] ] ) 
在一个字符串中搜索指定的字符,返回发现指定的字符的位置。 
C1: 被搜索的字符串  
C2: 希望搜索的字符串  
I: 搜索的开始位置,缺省是1  
J: 出现的位置,缺省是1。 
SQL> SELECT INSTR ('Oracle Training', 'ra', 1, 2) "Instring" FROM DUAL;
  Instring
----------
        9
INSTRB(<c1>,<c2>[,<I>[,<j>] ] )
除了返回的字节外 ,与INSTR              相同,
LENGTH( <c> )
返回字符串  c      的长度。
SQL> l 
 1  select name,length(name),addr,length(addr),sal,length(to_char(sal)) 
  2* from nchar_tst 
SQL> /
NAME    LENGTH(NAME) ADDR            LENGTH(ADDR) SAL LENGTH(TO_CHAR(SAL))
------   ------------  ----------------  ------------  ----------  ----------------
赵元杰          3        北京市海淀区                 6         99999.99    8
LENGTHB( <c> )
以字节返回字符串的字节数。
SQL> select name,lengthb(name),length(name) from nchar_tst;
NAME     LENGTHB(NAME)       LENGTH(NAME)
------   -------------   ------------
赵元杰                 6             3
LOWER ( <c> ) 
返回字符串并将所有字符变为小写。
SQL> select lower('AaBbCcDd') AaBbCcDd from dual;
AABBCCDD
--------
aabbccdd
UPPER( <c>) 
与  LOWER    相反,将给出字符串变为大写。如:
SQL>    select upper('AaBbCcDd') AaBbCcDd from dual;
AABBCCDD
--------
AABBCCDD 
RPAD 和LPAD(粘贴字符) 

RPAD(string,Length[,'set'])  
LPAD(string,Length[,'set'])  
      RPAD在列的右边粘贴字符;  
      LPAD在列的左边粘贴字符。  

例 1:  
SQL>select   RPAD(City,35,'.'),temperature    from  weather;  

        RPAD(City,35,'.')            temperature  
        -------------------------- ----------------  
           CLEVELAND......                    85  
           LOS  ANGELES..                     81  
          .........................  

        (即不够 35 个字符用'.'填满) 
LTRIM(左截断)RTRIM(右截断) 函数  

LTRIM (string [,’set’])
Left TRIM (左截断)删去左边出现的任何set 字符。 
RTRIM (string [,’set’])
Right TRIM (右截断)删去右边出现的任何set 字符。 
例1: 
SELECT RTRIM (‘Mother Theresa, The’, ‘The’) “Example of Right
Trimming” FROM DUAL;
Example of Right
----------------
Mother Theresa,
SUBSTR Substr(string,start[,Count])
取子字符串中函数  
对字串 (或字段),从 start字符 开始,连续取 count 个字符并返回结果,如果没有指 count 
则一直取到尾。  

select phone,substr(phone,1,3) || ‘0’ || substr(phone,4)  
from telecommunication where master ’中国电信’;  

SUBSTRB(string,start[,Count]) 
对字串 (或字段),从 start字节 开始,连续取 count 个字节并返回结果,如果没有指 count 
则一直取到尾。  

REPLACE (‘string’ [,’string_in’,’string_out’])
String: 希望被替换的字符串或变量。  
String_in: 被替换字符串。  
String_out: 要替换字符串。  

SQL> select replace('Informaix 中国公司','Informaix','IBM Informix') 
  2  IBM 数据库  from dual;
IBM 数据库 
-------------------- 
IBM Informix 中国公司
SOUNDEX( <c> )
返回一个与给定的字符串读音相同的字符串(不管拼写是否一样)。
SELECT DPL_NAME FROM DENIED_PARTIES_LIST WHERE 
SOUNDEX(DPL_NAME) = SOUNDEX(‘Saddam Hussain’) ; 
DPL_NAME 
---------------------------------------------- 
Al Husseni 
Sadda Al Sada.
REPLACE (‘string’ [,’string_in’,’string_out’])
String:希望被替换的字符串或变量。  
String_in: 被替换字符串。  
String_out: 要替换字符串。  

SELECT REPLACE (‘Oracle’, ‘Or’, ‘Mir’) “Example “ FROM DUAL;  
Example  
-------  
Miracle 
TRIM  ( [<leading>] <trailing> FROM <trim_char>     ) 
RIM可以使你对给定的字符串进行裁剪(前面,后面或前后)。 
z 如果指定 LEADING, Oracle 从trim_char 中裁剪掉前面的字符;  
z 如果指定TRAILING, Oracle 从trim_char 中裁剪掉尾面的字符;  
z 如果指定两个都指定或一个都没有给出,Oracle从trim_char 中裁剪掉前面及尾面的字 
   符;  
z 如果不指定 trim_character, 缺省为空格符;  
z 如果只指定trim_source, Oracle Oracle从trim_char 中裁剪掉前面及尾面的字符。  

例子:将下面字符串中的前面和后面的‘0                   ‘字符都去掉:
SELECT TRIM (0 FROM 0009872348900) "TRIM Example" FROM DUAL;
TRIM example
--------------------------------
98723489

语法:TRANSLATE(expr,from,to)
om,to) expr: 代表一串字符,
expr: 代表一串字符,from 与 to 是从左到右一一对应的关系,如果不能对应,则视为空值。
举例:
select translate('abcbbaadef','ba','#@') from dual (b将被#替代,a将被@替代)
select translate(ab
select translate('abcbbaadef','bad','#@') from dual (b将被#替代,a将被@替代,
d对应的值是空值,将被移走)
因此:结果依次为:@#c##@@def 和@#c##@@ef





总结:
在oracle中  chr(13)、chr(10)、 chr(13)chr(10)在pl/sql中的16进制表示都是0D0A,
说明这三种表示都能代表 光标移到行首并且换一行;
而chr(13)chr(13)、chr(10)chr(10)、chr(10)chr(13) 
在pl/sql中用16进制表示是0D0A0D0A,表明是两次回车换行;


  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值