java字符串中英文_如何从Java编码中截取给定宽度中英文字符串?

a4c26d1e5885305701be709a3d33442f.png

如何从Java编码中截取给定宽度中英文字符串?

(2007-12-18 15:18:28)

标签:

IT/科技

转自http://www.webdn.com/web_file/java/0706072.asp 【摘 要】

后来仔细研究了一下,可以这样解决:从字符串转换成byte,然后判断汉字的个数,是汉字就取占两个空,不是汉字就占一个空.这就是为什么一开始我要提提Java中的bytechar.

Java内核是unicode的,就连class文件也是,但是很多媒体,包括文件/流的保存方式是使用字节流的。

因此Java要对这些字节流经行转化。

char是unicode的,而byte是字节。我们在写JSP页面时可能没注意到JSP作为回显终端,也是byte的,所以在从JSP页面中读取表单和写入数据

(Javabean)时要注意页面的编码.

一个传统的解决方案是所有的应用包括页面编码设置\数据库编码设置都设定一致,比如gbk(gbk是gb2312的扩展集,支持的字符要多些).

现在又有个问题了,既然Java内核是unicode的编码,那么字符串String

lml="我爱金信桥tbs,tbs金信桥爱我"的长度应该是中文字符和英文字符的个数和,即lml.length()==17.

好了,如果我们想截取长度为14的字符串,那么应该:lml.substring(0,13);返回“我爱金信桥tbs,tbs金”.

这没问题吧?

但如果是应用中要求我们截取"固定回显长度"的字符串回显到JSP页面,那应该怎么办呢?所谓“固定回显长度”是指一个区域纯英文能显示x个,纯中文能显示x/2个.假设一个JSP页面中,有个表格,其中一列宽度为13个纯英文字符,我们想显示主题,主题可以为中文或英文.如果我们简单地设定了取前13个字符,那么在英文情况下是没问题的,能正确显示截取的前13个.

但汉字呢?一个汉字要占两个英文的宽度的.所以取了13个汉字就超过了列的宽度,破坏了布局.

那取6个字符好了!

恩,这到是没破坏布局,但你不觉得英文的情况下浪费了一般的宽度么?

哦,那就不好办了,中英文混合的串确实麻烦...

我在做mail系统时,在邮件列表中有一列加上了正文的内容提示(前50个字符,有点类似gmail),内容是可以有中文和英文混合的,所以为了尽量提示多些,不能采

用笨方法:直接取25个字符,保证中文没问题,英文浪费去吧~~~

后来仔细研究了一下,可以这样解决:从字符串转换成byte,然后判断汉字的个数,是汉字就取占两个空,不是汉字就占一个空.这就是为什么一开

始我要提提Java中的bytechar,o(∩_∩)o...哈哈

注意到这里有个trick,就是如果最后截取的是半个汉字,要丢弃掉!!否则,最后可能出现一个?号.

用法: string str=MyUtil.substring(lml,14); System.out.println(str);

输出: 我爱金信桥tbs, 核心代码如下: public static boolean

isLetter(char c) { int k = 0x80; return c / k == 0 ? true : false;

} public static int length(String s) { if (s == null) return 0;

char[] c = s.toCharArray(); int len = 0; for (int i = 0; i <

c.length; i++) { len++; if (!isLetter(c[i])) { len++; } } return

len; } public static String substring(String origin, int len) { if

(origin == null || origin.equals("")||len<1) return ""; byte[]

strByte = new byte[len]; if (len > MyUtil.length(origin)){

return origin;} System.arraycopy(origin.getBytes(), 0, strByte, 0,

len); int count = 0; for (int i = 0; i < len; i++) { int value =

(int) strByte[i]; if (value < 0) { count++; } } if (count % 2 !=

0) { len = (len == 1) ? ++len : --len; } return new String(strByte,

0, len); }

分享:

a4c26d1e5885305701be709a3d33442f.png喜欢

0

a4c26d1e5885305701be709a3d33442f.png赠金笔

加载中,请稍候......

评论加载中,请稍候...

发评论

登录名: 密码: 找回密码 注册记住登录状态

昵   称:

评论并转载此博文

a4c26d1e5885305701be709a3d33442f.png

发评论

以上网友发言只代表其个人观点,不代表新浪网的观点或立场。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值