java提取字符从mysql_java和Js 按字节来截取字符串长度(为了符合数据库varchar)

/**

* 截取符合oracle varchar长度的字符集

*

* @author 陈兵

*

*/

public class SplitString {

public static String subStringByByte(String str,int byteNum) throws Exception {

byte bt[] = str.getBytes();

System.out.println(" Length of this String ===> " + bt.length );

if (byteNum >= 1) {

if (byteNum > bt.length ){

String substrx = new String(bt, 0, bt.length);

return substrx;

} else{

String substrex = new String(bt, 0, byteNum);

return substrex;

}

} else {

System.out.println("输入错误!!!请输入大于零的整数:");

throw new Exception();

}

}

public static void main(String[] args){

String str = "我我我ABC汉DEF我我我ABC汉DEF我我我ABC汉DEF我我我ABC汉DEF我我我ABC汉DEF我我我ABC汉DEF我我我ABC汉DEF我我我ABC汉DEF我我我ABC汉DEF我我我ABC汉DEF我我我ABC汉DEF我我我ABC汉DEF我我我ABC汉DEF我我我ABC汉DEF我我我ABC汉DEF我我我ABC汉DEF我我我ABC汉DEF";

for(int i=1;i<=100;i++){

try {

String res = subStringByByte(str, i);

System.out.println(res);

} catch (Exception e) {

// TODO 自动生成 catch 块

e.printStackTrace();

}

}

}

}

JS的截取方法:

function substr(str, len)

{

if( ! str || ! len)

{

return '';

}

// 预期计数:中文2字节,英文1字节

var a = 0;

// 循环计数

var i = 0;

// 临时字串

var temp = '';

for (i = 0; i < str.length; i ++ )

{

if (str.charCodeAt(i) > 255)

{

// 按照预期计数增加2

a += 2;

}

else

{

a ++ ;

}

// 如果增加计数后长度大于限定长度,就直接返回临时字符串

if(a > len)

{

return temp;

}

// 将当前内容加到临时字符串

temp += str.charAt(i);

}

// 如果全部是单字节字符,就直接返回源字符串

return str;

}

分享到:

18e900b8666ce6f233d25ec02f95ee59.png

72dd548719f0ace4d5f9bca64e1d7715.png

2012-12-04 13:40

浏览 2239

评论

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值