首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > 开发语言 > 编程 >

java全角与半角字符交换

2012-10-29 
java全角与半角字符互换此代码来源于网络,贴在这里是为了自己能快速的找到加以使用,而且公司有网站屏蔽,对

java全角与半角字符互换

此代码来源于网络,贴在这里是为了自己能快速的找到加以使用,而且公司有网站屏蔽,对此网站没有屏蔽,所以有很多代码都是在家里找到然后传到此网站,以备工作使用.

?

java全角半角之间的相互转化[转]

System.out.println(QJstr1 + "\n" + result1);
}

// 半角全角
public static final String BQchange(String QJstr) {
String outStr = "";
String Tstr = "";
byte[] b = null;

for (int i = 0; i< QJstr.length(); i++) {
try {
Tstr = QJstr.substring(i, i + 1);
b = Tstr.getBytes("unicode");
} catch (java.io.UnsupportedEncodingException e) {
e.printStackTrace();
}
if (b[3] != -1) {
b[2] = (byte) (b[2] - 32);
b[3] = -1;
try {
outStr = outStr + new String(b, "unicode");
} catch (java.io.UnsupportedEncodingException e) {
e.printStackTrace();
}
} else
outStr = outStr + Tstr;
}
return outStr;
}

// 全角半角
public static final String QBchange(String QJstr) {
String outStr = "";
String Tstr = "";
byte[] b = null;

for (int i = 0; i< QJstr.length(); i++) {
try {
Tstr = QJstr.substring(i, i + 1);
b = Tstr.getBytes("unicode");
} catch (java.io.UnsupportedEncodingException e) {
e.printStackTrace();
}
if (b[3] == -1) {
b[2] = (byte) (b[2] + 32);
b[3] = 0;
try {
outStr = outStr + new String(b, "unicode");
} catch (java.io.UnsupportedEncodingException e) {
e.printStackTrace();
}
} else
outStr = outStr + Tstr;
}
return outStr;
}
}

//从这里以上的代码我测试过,不过没有什么效果,不知道网上为什么会一直流传,还是我使用的方法不对呢?

//如果有知道的希望能告诉告诉我,上面的代码的具体作用

/**/// /
// / 转全角的函数(SBC case)
// /
// / 任意字符串
// /全角字符串
// /
// /全角空格为12288,半角空格为32
// /其他字符半角(33-126)与全角(65281-65374)的对应关系是:均相差65248
// /
public static String ToSBC(String input) {
// 半角全角
char[] c = input.toCharArray();
for (int i = 0; i< c.length; i++) {
if (c[i] == 32) {
c[i] = (char) 12288;
continue;
}
if (c[i]< 127)
c[i] = (char) (c[i] + 65248);
}
return new String(c);
}

/**/// /
// / 转半角的函数(DBC case)
// /
// / 任意字符串
// /半角字符串
// /
// /全角空格为12288,半角空格为32
// /其他字符半角(33-126)与全角(65281-65374)的对应关系是:均相差65248
// /
public static String ToDBC(String input) {
char[] c = input.toCharArray();
for (int i = 0; i< c.length; i++) {
if (c[i] == 12288) {
c[i] = (char) 32;
continue;
}
if (c[i]> 65280&& c[i]< 65375)
c[i] = (char) (c[i] - 65248);
}
return new String(c);
}

热点排行