这是本人与同事在工作中对字符串处理的总结,发表出来,希望对大家有些帮助,也希望大家给予指正,谢谢!~
import java.util.*;
/**
*
文件标题:
*
*
关于字符串的一些处理方法:
* @版本 1.0
*/
public class stringutil {
public stringutil() {
}
/**
* @description 字符串替代函数
* @param source string 源字符串
* @param be_rep_str string 需要被替换的子串
* @param rep_str string 要替换的目标串
* @param return_str string
* @return string
*/
public static string replacestr(string source, string be_rep_str,
string rep_str, string return_str) {
if (source.indexof(be_rep_str) < 0) {
return source;
}
else {
string head = source.substring(0, source.indexof(be_rep_str));
string body = rep_str +
source.substring(source.indexof(be_rep_str) + be_rep_str.length());
return_str = replacestr(head + body, be_rep_str, rep_str,
return_str);
}
return return_str;
}
public static string[] getfields(string test, string sep) { //坼分字符,将字句test按照sep进行坼分。
sep = "\u0020";
if (test.indexof(sep) != -1) {
if ( (test.indexof(sep) > test.indexof("#")) &&
test.indexof("#") != -1) {
sep = "#";
}
}
else {
sep = "#";
}
string[] st;
list flds = new arraylist();
if (sep.equals("\u0020")) {
stringtokenizer stto = new stringtokenizer(test.trim(), sep);
while (stto.hasmoretokens()) {
flds.add(stto.nexttoken());
}
st = (string[]) flds.toarray(new string[stto.counttokens()]);
}
else {
st = test.trim().split(sep);
}
return st;
}
// public string dbc2sbc(string str)
// {
// int i ;
// string result = "";
// for (i = 0 ; i < str.length(); i++)
// {
// code = str.charcodeat(i) ;
// // “65281”是“!”,“65373”是“}”
// if (code >= 65281 && code < 65373)
// // “65248”是转换码距
// result += string.fromcharcode(str.charcodeat(i) - 65248) ;
// else
// result += str.charat(i) ;
// }
// return result ;
// }
/**
* 半角 dbc case -> 全角 sbc case
* @param qjstr string
* @return string
*/
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;
}
/**
* 全角 转换成 -> 半角
* @param qjstr string
* @return string
*/
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;
}
public static void main(string aa[]) {
string qj = "#?¥%……?*()";
string bj = "#@$%^&*()";
system.out.println("半角转换成全角:" + bj + " --> " + bqchange(bj));
string s = " ";
string qs = " ";
system.out.println("全角转换成半角:"+qj + " -->" + qbchange(qj));
system.out.println( (int) (qbchange(qs).tochararray()[0]));
system.out.println( (int) s.tochararray()[0]);
string dd[] = getfields("23#99#99#99", "#");
for (int i = 0; i < dd.length; i++) {
system.out.println("asfd" + dd[i]);
}
system.out.println(dd.length);
}
}
闽公网安备 35060202000074号