StringUtil

package org.jr.util;

/**
 * Copyright: Copyright (c) 2002-2003
 * Company: JavaResearch(http://www.javaresearch.org)
 * 最后更新日期:2003年3月31日
 * @author Cherami
 */

import java.io.*;
import java.util.*;
import java.text.*;

/**
 * 此类中封装一些常用的字符串操作。
 * 所有方法都是静态方法,不需要生成此类的实例,
 * 为避免生成此类的实例,构造方法被申明为private类型的。
 * @since  0.1
 */
public class StringUtil {
  /**
   * 私有构造方法,防止类的实例化,因为工具类不需要实例化。
   */
  private StringUtil() {
  }

  /**
   * 此方法将给出的字符串source使用delim划分为单词数组。
   * @param source 需要进行划分的原字符串
   * @param delim 单词的分隔字符串
   * @return 划分以后的数组,如果source为null的时候返回以source为唯一元素的数组,
   *         如果delim为null则使用逗号作为分隔字符串。
   * @since  0.1
   */
  public static String[] split(String source, String delim) {
    String[] wordLists;
    if (source == null) {
      wordLists = new String[1];
      wordLists[0] = source;
      return wordLists;
    }
    if (delim == null) {
      delim = ",";
    }
    StringTokenizer st = new StringTokenizer(source, delim);
    int total = st.countTokens();
    wordLists = new String[total];
    for (int i = 0; i < total; i++) {
      wordLists[i] = st.nextToken();
    }
    return wordLists;
  }

  /**
   * 此方法将给出的字符串source使用delim划分为单词数组。
   * @param source 需要进行划分的原字符串
   * @param delim 单词的分隔字符
   * @return 划分以后的数组,如果source为null的时候返回以source为唯一元素的数组。
   * @since  0.2
   */
  public static String[] split(String source, char delim) {
    return split(source, String.valueOf(delim));
  }

  /**
   * 此方法将给出的字符串source使用逗号划分为单词数组。
   * @param source 需要进行划分的原字符串
   * @return 划分以后的数组,如果source为null的时候返回以source为唯一元素的数组。
   * @since  0.1
   */
  public static String[] split(String source) {
    return split(source, ",");
  }

  /**
   * 循环打印字符串数组。
   * 字符串数组的各元素间以指定字符分隔,如果字符串中已经包含指定字符则在字符串的两端加上双引号。
   * @param strings 字符串数组
   * @param delim 分隔符
   * @param out 打印到的输出流
   * @since  0.4
   */
  public static void printStrings(String[] strings, String delim,
                                  OutputStream out) {
    try {
      if (strings != null) {
        int length = strings.length - 1;
        for (int i = 0; i < length; i++) {
          if (strings[i] != null) {
            if (strings[i].indexOf(delim) > -1) {
              out.write( ("\"" + strings[i] + "\"" + delim).getBytes());
            }
            else {
              out.write( (strings[i] + delim).getBytes());
            }
          }
          else {
            out.write("null".getBytes());
          }
        }
        if (strings[length] != null) {
          if (strings[length].indexOf(delim) > -1) {
            out.write( ("\"" + strings[length] + "\"").getBytes());
          }
          else {
            out.write(strings[length].getBytes());
          }
        }
        else {
          out.write("null".getBytes());
        }
      }
      else {
        out.write("null".getBytes());
      }
      out.write(Constants.LINE_SEPARATOR.getBytes());
    }
    catch (IOException e) {

    }
  }

  /**
   * 循环打印字符串数组到标准输出。
   * 字符串数组的各元素间以指定字符分隔,如果字符串中已经包含指定字符则在字符串的两端加上双引号。
   * @param strings 字符串数组
   * @param delim 分隔符
   * @since  0.4
   */
  public static void printStrings(String[] strings, String delim) {
    printStrings(strings, delim, System.out);
  }

  /**
   * 循环打印字符串数组。
   * 字符串数组的各元素间以逗号分隔,如果字符串中已经包含逗号则在字符串的两端加上双引号。
   * @param strings 字符串数组
   * @param out 打印到的输出流
   * @since  0.2
   */
  public static void printStrings(String[] strings, OutputStream out) {
    printStrings(strings, ",", out);
  }

  /**
   * 循环打印字符串数组到系统标准输出流System.out。
   * 字符串数组的各元素间以逗号分隔,如果字符串中已经包含逗号则在字符串的两端加上双引号。
   * @param strings 字符串数组
   * @since  0.2
   */
  public static void printStrings(String[] strings) {
    printStrings(strings, ",", System.out);
  }

  /**
   * 将字符串中的变量使用values数组中的内容进行替换。
   * 替换的过程是不进行嵌套的,即如果替换的内容中包含变量表达式时不会替换。
   * @param prefix 变量前缀字符串
   * @param source 带参数的原字符串
   * @param values 替换用的字符串数组
   * @return 替换后的字符串。
   *         如果前缀为null则使用“%”作为前缀;
   *         如果source或者values为null或者values的长度为0则返回source;
   *         如果values的长度大于参数的个数,多余的值将被忽略;
   *         如果values的长度小于参数的个数,则后面的所有参数都使用最后一个值进行替换。
   * @since  0.2
   */
  public static String getReplaceString(String prefix, String source,
                                        String[] values) {
    String result = source;
    if (source == null || values == null || values.length < 1) {
      return source;
    }
    if (prefix == null) {
      prefix = "%";
    }

    for (int i = 0; i < values.length; i++) {
      String argument = prefix + Integer.toString(i + 1);
      int index = result.indexOf(argument);
      if (index != -1) {
        String temp = result.substring(0, index);
        if (i < values.length) {
          temp += values[i];
        }
        else {
          temp += values[values.length - 1];
        }
        temp += result.substring(index + 2);
        result = temp;
      }
    }
    return result;
  }

  /**
   * 将字符串中的变量(以“%”为前导后接数字)使用values数组中的内容进行替换。
   * 替换的过程是不进行嵌套的,即如果替换的内容中包含变量表达式时不会替换。
   * @param source 带参数的原字符串
   * @param values 替换用的字符串数组
   * @return 替换后的字符串
   * @since  0.1
   */
  public static String getReplaceString(String source, String[] values) {
    return getReplaceString("%", source, values);
  }

  /**
   * 字符串数组中是否包含指定的字符串。
   * @param strings 字符串数组
   * @param string 字符串
   * @param caseSensitive 是否大小写敏感
   * @return 包含时返回true,否则返回false
   * @since  0.4
   */
  public static boolean contains(String[] strings, String string,
                                 boolean caseSensitive) {
    for (int i = 0; i < strings.length; i++) {
      if (caseSensitive == true) {
        if (strings[i].equals(string)) {
          return true;
        }
      }
      else {
        if (strings[i].equalsIgnoreCase(string)) {
          return true;
        }
      }
    }
    return false;
  }

  /**
   * 字符串数组中是否包含指定的字符串。大小写敏感。
   * @param strings 字符串数组
   * @param string 字符串
   * @return 包含时返回true,否则返回false
   * @since  0.4
   */
  public static boolean contains(String[] strings, String string) {
    return contains(strings, string, true);
  }

  /**
   * 不区分大小写判定字符串数组中是否包含指定的字符串。
   * @param strings 字符串数组
   * @param string 字符串
   * @return 包含时返回true,否则返回false
   * @since  0.4
   */
  public static boolean containsIgnoreCase(String[] strings, String string) {
    return contains(strings, string, false);
  }

  /**
   * 将字符串数组使用指定的分隔符合并成一个字符串。
   * @param array 字符串数组
   * @param delim 分隔符,为null的时候使用""作为分隔符(即没有分隔符)
   * @return 合并后的字符串
   * @since  0.4
   */
  public static String combineStringArray(String[] array, String delim) {
    int length = array.length - 1;
    if (delim == null) {
      delim = "";
    }
    StringBuffer result = new StringBuffer(length * 8);
    for (int i = 0; i < length; i++) {
      result.append(array[i]);
      result.append(delim);
    }
    result.append(array[length]);
    return result.toString();
  }

  /**
   * 以指定的字符和长度生成一个该字符的指定长度的字符串。
   * @param c 指定的字符
   * @param length 指定的长度
   * @return 最终生成的字符串
   * @since  0.6
   */
  public static String fillString(char c,int length) {
    String ret = "";
    for (int i=0; i<length; i++) {ret += c;}
    return ret;
  }

  /**
   * 去除左边多余的空格。
   * @param value 待去左边空格的字符串
   * @return 去掉左边空格后的字符串
   * @since  0.6
   */
  public static String trimLeft(String value) {
    String result = value;
    if(result == null) return result;
    char ch[] = result.toCharArray();
    int index = -1;
    for(int i=0; i < ch.length ; i++) {
      if(Character.isWhitespace(ch[i])) {
        index = i;
      }
      else {
        break;
      }
    }
    if(index != -1) {
      result = result.substring(index+1);
    }
    return result;
  }

  /**
   * 去除右边多余的空格。
   * @param value 待去右边空格的字符串
   * @return 去掉右边空格后的字符串
   * @since  0.6
   */
  public static String trimRight(String value) {
    String result = value;
    if(result == null) return result;
    char ch[] = result.toCharArray();
    int endIndex = -1;
    for(int i=ch.length-1; i > -1; i--) {
      if(Character.isWhitespace(ch[i])) {
        endIndex = i;
      }
      else {
        break;
      }
    }
    if(endIndex != -1) {
      result = result.substring(0, endIndex);
    }
    return result;
  }

  /**
   * 根据转义列表对字符串进行转义。
   * @param source 待转义的字符串
   * @param escapeCharMap 转义列表
   * @return 转义后的字符串
   * @since  0.6
   */
  public static String escapeCharacter(String source, HashMap escapeCharMap) {
    if (source == null || source.length() == 0) return source;
    if (escapeCharMap.size() == 0) return source;
    StringBuffer sb = new StringBuffer();
    StringCharacterIterator sci = new StringCharacterIterator(source);
    for (char c = sci.first(); c != StringCharacterIterator.DONE; c = sci.next()) {
      String character = String.valueOf(c);
      if (escapeCharMap.containsKey(character))
        character = (String)escapeCharMap.get(character);
      sb.append(character);
    }
    return sb.toString();
  }
  /**
   * 得到字符串的字节长度
   * @param source 字符串
   * @return 字符串的字节长度
   * @since  0.6
   */
  public static int getByteLength(String source){
   int len = 0;
   for(int i=0;i<source.length();i++){
    char c = source.charAt(i);
    int highByte = c >>> 8;
    len += highByte==0?1:2;
   }
   return len;
  }
}

posted on 2004-11-16 21:56  笨笨  阅读(3261)  评论(0编辑  收藏  举报

导航