频道直达 - 专题 - 新闻 - 技巧 - 组网 - 开发 - 安全 - web编程 - 图像 - 操作系统 - 数据库 - 教育 - 旅游 - 健康 - 时尚 - 驱动 - 软件 - 游戏 - 多媒体 - ERP - 讨论组

J2SE综合-关于字符串的一些处理技巧

来源:本站原创 作者:佚名 出处:巧巧读书 2008-03-03 进入讨论组

  这是本人与同事在工作中对字符串处理的总结,发表出来,希望对大家有些帮助,也希望大家给予指正,谢谢!~

  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);
  }
}

正文:http://www.qqread.com/java/2008/03/w399574.html 更多文章 更多内容请看Office技巧专区网管实用技巧100例数据库处理专题专题,或进入讨论组讨论。
收藏此文】【 】【打印】【关闭
相关图文阅读
频道图文推荐
健 康 咨 询
时 尚 咨 询
巧巧读书宗旨
相关专题
讨论组问题推荐
站内各频道最新更新文档
站内最新制作专题
热门关键字导读
Photoshop教 程照片处理 照片制作 PS快捷键 抠图
计 算 机 故 障XP系统修复
艺 术 与 设 计设计 流媒体 设计欣赏 边框
计 算 机 安 全ARP
站内频道文章精选
巧巧电脑频道编辑信箱  告诉我们您想看的专题或文章