日期:2014-05-20  浏览次数:21020 次

j2me工具类:ReadFromFile.java
import java.io.*;
import java.util.Vector;

/*
 * 用法:
 *  	ReadFromFile rf = new ReadFromFile("/res/A.txt");
	    Vector v = rf.parseFile();
	    String temp=null;
	    String[] annonce=new String[v.size()];
	    for(int i=0;i<v.size();i++){
	    	temp = (String) v.elementAt(i);//tmp为16进制的字符串(UTF8)
	    	annonce[i] = TypeConvert.gb2utf(TypeConvert.toHex(temp));
	    	 System.out.println("annonce="+annonce[i]);//中文
	    }
 */


public class ReadFromFile {
	public InputStream in;

	public ReadFromFile(String file_path) throws IOException {
		in = this.getClass().getResourceAsStream(file_path);
	}

	//读取所有行,存入Vector
	public Vector parseFile() throws IOException {
		Vector vec = new Vector();
		String line = null;
		while ((line = this.readLine()) != null && line.length() > 0) {
			if (line.startsWith("#")) {//#注释
			} else {
				vec.addElement(line);
			}
		}
		return vec;
	}

	private String readLine() throws IOException {
		StringBuffer buffer = new StringBuffer();
		boolean isEndOfFile = false;
		if (in != null) {
			while (true) {
				int ch = in.read() & 0xFF;
				if (ch == 0xD) { // '13' '\n'
				} else if (ch == 0xA) {
					break;
				} else if (ch == 0xFF) {
					isEndOfFile = true;
					break;
				} else {
					buffer.append((char) ch);
				}
			}
		}
		if (isEndOfFile) {
			if (buffer.length() > 0) {
				return buffer.toString();
			} else {
				return null;
			}
		}
		return buffer.toString();
	}
	
	
	/////////////////////////////////////////////////////////////////////////////////
	
	
	//一,读取Unicode格式

    private String read_Uni(String resource)
    {
        byte word_uni[]=new byte[1024];
        String strReturn="";
        InputStream is;
        try
        {
            is=getClass().getResourceAsStream(resource);
            is.read(word_uni);
            is.close();
            StringBuffer stringbuffer = new StringBuffer("");
            for (int j = 0; j < word_uni.length; )
            {
              int k = word_uni[j++]; //注意在这个地方进行了码制的转换
              if (k < 0)
                k += 256;
              int l = word_uni[j++];
              if (l < 0)
                l += 256;
              char c = (char) (k + (l << 8)); //把高位和低位数组装起来
              stringbuffer.append(c);
            }
            strReturn=stringbuffer.toString();
        }
        catch(IOException e)
        {
            e.printStackTrace();
        }
        finally
        {
            is=null;
        }
        return strReturn;
    }


//二,读取UTF-8格式

    public String read_UTF(String name)
    {
        String strReturn = "";
        InputStream in = null;
        byte[] word_utf= new byte[1024];
        try
        {
          in = getClass().getResourceAsStream(name);
          in.read(word_utf);
          in.close();
          strReturn=new String(word_utf,"UTF-8");
        }
        catch(Exception e)
        {
          System.out.println("readUTF Error:"+e.toString());
        }
        finally
        {
          in = null;
        }
        return strReturn;
    }

/*三,读取Unicode big endian格式

读取Unicode big endian格式时,采用readChar()方法读取,所以存放时使用char数组存放.

注意:在文本的末尾加上'$'表示文本的结束.

另外代码第10行dis.skip(2)是略过文件头2个字符,如果用microsoft notepad保存的一定存在这两个头字符.

当然,可以使用UltraEdit可以先删掉这两个头字符,然后使用新建文件,复制粘贴,保存为其它格式.这样两个头字符就没了..
*/

    private String read_Uni_b_e(String resource)
    {
        char word_uni_b_e[]=new char[1024];
        String strReturn="";
        DataInputStream dis;
        try
        {
            dis=new DataInputStream(getClass().getResourceAsStream(resource));
            int counter=0;
            dis.skip(2);
            char temp;
            while(true)
            {
                temp=dis.readChar();
                if(temp=='$')
                    break;
                word_uni_b_e[counter++]=temp;
            }
            dis.close();
            strReturn=String.valueOf(word_uni_b_e,0,counter);
        }
        catch(Exception e)
        {
            System.out.println("read_Uni_b_e error!"+e.getMessage());
        }
        finally
        {
            dis=null;
        }
        return strReturn;
    }


	////////////////////////////////////////////////////////////////////////////////
    
    
    /**
    *
    * @todo 一定要确定读取的文件为utf-8格式要不然会出错,用ue可以转换成utf-8
    * @param name
    *            String
    * @return String
    */
   public String readUTF(String path) {
    String strReturn = "";
    int ic;
    InputStream in = null;
    ByteArrayOutputStream baos = new ByteArrayOutputStream();
    DataOutputStream dos = new DataOutputStream(baos);
    byte[] myData;
    byte[] buffer = new byte[1024];
    try {
     in = getClass().getResourceAsStream(path);
     if (in != null) {
      while ((ic = in.read(buffer)) > 0) {
       dos.write(buffer, 0, ic);
      }
      myData = baos.toByteArray();
      strReturn = new String(myData, "UTF-8");
      in.close();
     }
     dos.close();
     baos.close();
    } catch (Exception e) {
     System.out.println("readUTF Error:" + e.toString());
    } finally {
     in = null;
     dos = null;
     baos = null;
    }
    return strReturn;
   } 
}


/*用法:
TypeConvert.gb2utf(TypeConvert.toHex(tmp));
其中tmp如E6ACA2E8BF8EE682A8E4BDBFE794A8E4BFA1E794A8E58DA1E4BCB4E4BEA3E8BDAFE4BBB6EFBC8CE5BD93E5898DE78988E69CACE58FB7E4B8BA56322E38E38082E69CACE8BDAFE4BBB6E698AFE5858DE8B4B9E8BDAFE4BBB6EFBC8CE68891E4BBACE4B88DE4BC9AE59091E682A8E694B6E58F96E8BDAFE4BBB6E4BDBFE794A8E8B4B9EFBC8CE8AFB7E694BEE5BF83E4BDBFE794A8E38082
形式。
*/

/**
 * <p>Title: </p>
 *
 * <p>Description: </p>
 *
 * <p>Copyright: Copyright (c) 2008</p>
 *
 * <p>Company: WorthTech</p>
 *
 * @author bruce
 * @version 1.0
 */
import java.io.UnsupportedEncodingException;

public class TypeConvert {

    public static String toHexString(byte[] value) {
        String newString = "";
        for (int i = 0; i < value.length; i++) {
            byte b = value[i];
            String str = Integer.toHexString(b);
            if (str.length() > 2) {
                str = str.substring(str.length() - 2);
            }
            if (str.length() < 2) {
                str = "0" + str;
            }
            newString += str;
        }
        return newString.toUpperCase();
    }

    public static byte[] toHex(String hexString) {
        int len = hexString.length() / 2;
        byte[] newByte = new byte[len];
        for (int i = 0; i < len; i++) {
            newByte[i] = toByte(hexString.substring(i * 2, (i + 1) * 2));
        }
        return newByte;
    }

    public static byte toByte(String data) {
        return (byte) Integer.parseInt(data, 16);
    }

    public static int toInt(String data) {
        return Integer.parseInt(data, 16);
    }

    public static int hex2int(byte[] data) {
        return toInt(toHexString(data));
    }

    public static byte[] int2byte(int n) {
        byte[] b = new byte[4];
        b[0] = (byte) (n >> 24);
        b[1] = (byte) (n >> 16);
        b[2] = (byte) (n >> 8);
        b[3] = (byte) n;
        return b;
    }
    /*使用指定字符填充字符串
     * 需要格式化的字符串:strSrc
     * 需要填充的字符:chFormat
     * 需要填充的长度:nFormatLen
     */
    public static String leftFormatString(String strSrc, char chFormat, int nFormatLen) {
        if (strSrc == null) {
            strSrc = "";
        }
        int nLen = strSrc.length();
        if (nLen < nFormatLen) {
            String strNum = "";
            for (int i = 0; i < nFormatLen - nLen; i++) {
                strNum = strNum + chFormat;
            }
            return strNum + strSrc;
        } else {
            return strSrc;
        }
    }

    public static String rightFormatString(String strSrc, char chFormat, int nFormatLen) {
        if (strSrc == null) {
            strSrc = "";
        }
        int nLen = strSrc.getBytes().length;
        if (nLen < nFormatLen) {
            String strNum = "";
            for (int i = 0; i < nFormatLen - nLen; i++) {
                strNum = strNum + chFormat;
            }
            return strSrc + strNum;
        } else {
            return strSrc;
        }
    }

    public static String byte2hexBcd(byte[] b) {
        if (b == null) {
            return "字节数组为空";
        }
        String hs = "";
        String stmp = "";
        for (int n = 0; n < b.length; n++) {
            stmp = Integer.toHexString(b[n] & 0xFF);
            if (stmp.length() == 1) {
                hs = hs + "0" + stmp;
            } else {
                hs = hs + stmp;
            }
        }
        return hs.toUpperCase();
    }

    public static byte[] str2bcd(String asc) {
        int len = asc.length();
        int mod = len % 2;

        if (mod != 0) {
            asc = "0" + asc;
            len = asc.length();
        }

        byte abt[] = new byte[len];
        if (len >= 2) {
            len = len / 2;
        }

        byte bbt[] = new byte[len];
        abt = asc.getBytes();
        int j, k;

        for (int p = 0; p < asc.length() / 2; p++) {
            if ((abt[2 * p] >= '0') && (abt[2 * p] <= '9')) {
                j = abt[2 * p] - '0';
            } else if ((abt[2 * p] >= 'a') && (abt[2 * p] <= 'z')) {
                j = abt[2 * p] - 'a' + 0x0a;
            } else {
                j = abt[2 * p] - 'A' + 0x0a;
            }

            if ((abt[2 * p + 1] >= '0') && (abt[2 * p + 1] <= '9')) {
                k = abt[2 * p + 1] - '0';
            } else if ((abt[2 * p + 1] >= 'a') && (abt[2 * p + 1] <= 'z')) {
                k = abt[2 * p + 1] - 'a' + 0x0a;
            } else {
                k = abt[2 * p + 1] - 'A' + 0x0a;
            }

            int a = (j << 4) + k;
            byte b = (byte) a;
            bbt[p] = b;
        }
        return bbt;
    }

    public static String gb2utf(byte[] gbString) throws UnsupportedEncodingException {
        return new String(gbString, "UTF-8");
    }
}