Chinaunix首页 | 论坛 | 博客
  • 博客访问: 347897
  • 博文数量: 25
  • 博客积分: 3011
  • 博客等级: 中校
  • 技术积分: 367
  • 用 户 组: 普通用户
  • 注册时间: 2008-11-28 13:22
个人简介

生命在于折腾

文章分类

全部博文(25)

文章存档

2015年(1)

2011年(3)

2010年(4)

2009年(17)

我的朋友

分类: 敏捷开发

2010-01-27 11:09:16

1,在Non-Unicode系统中,一个汉字占2个单位长度,可以用CHARLEN的返回值判断是否汉字。
 
DATA: len TYPE i,
         str TYPE c LENGTH 20.
 
str = 'Hello哈哈'.
len = CHARLEN( str )."1,代表英文
len = CHARLEN( str+4 )."1,代表英文
len = CHARLEN( str+5 )."2,代表汉字
len = CHARLEN( str+6 )."2,代表汉字
 
2,在Unicode系统中,汉字与英文一样占1个单位长度,可以调用函数NLS_VISUAL_CHARLEN来判断。
 
DATA: c1 type char1,
         vislen type i.
 
c1 = 'A'.
*c1 = '哈'.
 
CALL FUNCTION 'NLS_VISUAL_CHARLEN'
  EXPORTING
    str        = c1
  IMPORTING
    len_visual = vislen.
 
IF vislen = 1.
  WRITE: '英文'.
ELSE.
  WRITE: '汉字'.
ENDIF.

 
阅读(7027) | 评论(2) | 转发(0) |
给主人留下些什么吧!~~

chinaunix网友2010-02-08 11:22:54

哦~~是这样啊,领教了

chinaunix网友2010-01-29 15:02:20

呵呵,不通用啊。亚太很多国家的字都是两个字符的,比如日本。。。