java将日文半角片假名转成全角的方法

转载 2009年09月25日 14:59:00

package samples.string.japanese;

public class StringUtil {

  private static final char[] HANKAKU_KATAKANA = { '。', '「', '」', '、', '・',
      'ヲ', 'ァ', 'ィ', 'ゥ', 'ェ', 'ォ', 'ャ', 'ュ', 'ョ', 'ッ', 'ー', 'ア', 'イ',
      'ウ', 'エ', 'オ', 'カ', 'キ', 'ク', 'ケ', 'コ', 'サ', 'シ', 'ス', 'セ', 'ソ',
      'タ', 'チ', 'ツ', 'テ', 'ト', 'ナ', 'ニ', 'ヌ', 'ネ', 'ノ', 'ハ', 'ヒ', 'フ',
      'ヘ', 'ホ', 'マ', 'ミ', 'ム', 'メ', 'モ', 'ヤ', 'ユ', 'ヨ', 'ラ', 'リ', 'ル',
      'レ', 'ロ', 'ワ', 'ン', '゙', '゚' };

  private static final char[] ZENKAKU_KATAKANA = { '。', '「', '」', '、', '・',
      'ヲ', 'ァ', 'ィ', 'ゥ', 'ェ', 'ォ', 'ャ', 'ュ', 'ョ', 'ッ', 'ー', 'ア', 'イ',
      'ウ', 'エ', 'オ', 'カ', 'キ', 'ク', 'ケ', 'コ', 'サ', 'シ', 'ス', 'セ', 'ソ',
      'タ', 'チ', 'ツ', 'テ', 'ト', 'ナ', 'ニ', 'ヌ', 'ネ', 'ノ', 'ハ', 'ヒ', 'フ',
      'ヘ', 'ホ', 'マ', 'ミ', 'ム', 'メ', 'モ', 'ヤ', 'ユ', 'ヨ', 'ラ', 'リ', 'ル',
      'レ', 'ロ', 'ワ', 'ン', '゛', '゜' };

  private static final char HANKAKU_KATAKANA_FIRST_CHAR = HANKAKU_KATAKANA[0];

  private static final char HANKAKU_KATAKANA_LAST_CHAR = HANKAKU_KATAKANA[HANKAKU_KATAKANA.length - 1];

  /**
   * 半角カタカナから全角カタカナへ変換します。
   * @param c 変換前の文字
   * @return 変換後の文字
   */
  public static char hankakuKatakanaToZenkakuKatakana(char c) {
    if (c >= HANKAKU_KATAKANA_FIRST_CHAR && c <= HANKAKU_KATAKANA_LAST_CHAR) {
      return ZENKAKU_KATAKANA[c - HANKAKU_KATAKANA_FIRST_CHAR];
    } else {
      return c;
    }
  }
  /**
   * 2文字目が濁点・半濁点で、1文字目に加えることができる場合は、合成した文字を返します。
   * 合成ができないときは、c1を返します。
   * @param c1 変換前の1文字目
   * @param c2 変換前の2文字目
   * @return 変換後の文字
   */
  public static char mergeChar(char c1, char c2) {
    if (c2 == '゙') {
      if ("カキクケコサシスセソタチツテトハヒフヘホ".indexOf(c1) > 0) {
        switch (c1) {
        case 'カ': return 'ガ';
        case 'キ': return 'ギ';
        case 'ク': return 'グ';
        case 'ケ': return 'ゲ';
        case 'コ': return 'ゴ';
        case 'サ': return 'ザ';
        case 'シ': return 'ジ';
        case 'ス': return 'ズ';
        case 'セ': return 'ゼ';
        case 'ソ': return 'ゾ';
        case 'タ': return 'ダ';
        case 'チ': return 'ヂ';
        case 'ツ': return 'ヅ';
        case 'テ': return 'デ';
        case 'ト': return 'ド';
        case 'ハ': return 'バ';
        case 'ヒ': return 'ビ';
        case 'フ': return 'ブ';
        case 'ヘ': return 'ベ';
        case 'ホ': return 'ボ';
        }
      }
    } else if (c2 == '゚') {
      if ("ハヒフヘホ".indexOf(c1) > 0) {
        switch (c1) {
        case 'ハ': return 'パ';
        case 'ヒ': return 'ピ';
        case 'フ': return 'プ';
        case 'ヘ': return 'ペ';
        case 'ホ': return 'ポ';
        }
      }
    }
    return c1;
  }
  /**
   *
   * @param QJstr 変換前の文字目
   * @return 変換後の文字
   */
  private static String B2Q(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] == 0) {
              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 s 変換前文字列
   * @return 変換後文字列
   */
  public static String hankakuKatakanaToZenkakuKatakana(String s) {
    if (s.length() == 0) {
      return s;
    } else {
     s = B2Q(s);
     if (s.length() == 1) {
   return hankakuKatakanaToZenkakuKatakana(s.charAt(0)) + "";
     } else {
      
   StringBuffer sb = new StringBuffer(s);
   int i = 0;
   for (i = 0; i < sb.length() - 1; i++) {
    char originalChar1 = sb.charAt(i);
    char originalChar2 = sb.charAt(i + 1);
    char margedChar = mergeChar(originalChar1, originalChar2);
    if (margedChar != originalChar1) {
     sb.setCharAt(i, margedChar);
     sb.deleteCharAt(i + 1);
    } else {
     char convertedChar = hankakuKatakanaToZenkakuKatakana(originalChar1);
     if (convertedChar != originalChar1) {
      sb.setCharAt(i, convertedChar);
     }
    }
   }
   if (i < sb.length()) {
    char originalChar1 = sb.charAt(i);
    char convertedChar = hankakuKatakanaToZenkakuKatakana(originalChar1);
    if (convertedChar != originalChar1) {
     sb.setCharAt(i, convertedChar);
    }
   }
   return sb.toString();
     }
 }
  }

  public static void main(String[] args) {
    System.out.println(hankakuKatakanaToZenkakuKatakana("aaカ123"));
  }
}

相关文章推荐

日文 平假名转换为片假名(用ASCII码转换)

String ss = "あいうえお";for(int k = 0; k     char c = ss.charAt(k);    int i = c + 96;    char d = (char...

将日文半角片假名转换成全角片假名

//区別文字列は、arrayである。注:対象は、全角/半角の片仮名と英語文字のみに限られている。function my_split($string){ $count = mb_strlen($stri...

DELPIH 全角转成半角

  • 2010年05月28日 16:59
  • 776B
  • 下载

JAVA全角和半角的转换代码

  • 2009年02月02日 17:32
  • 55KB
  • 下载

Java工具类——全角半角字符相互转换

import org.apache.commons.lang.StringUtils;          /**    *     * 提供对字符串的全角->半角,半角->全角转换    *...

java全角半角转换程序

  • 2010年12月10日 01:03
  • 3KB
  • 下载

c#全角转化成半角源程序

  • 2011年03月31日 11:39
  • 34KB
  • 下载

JAVA实现全角半角相互转化 (full2Half & half2Full)

说明: 1.全角:指一个字符占用两个标准字符位置。汉字字符和规定了全角的英文字符及国标GB2312-80中的图形符号和特殊字符都是全角字符。一般的系统命令是不用全角字符的,只是在作文字处理时才会使用...
  • chndata
  • chndata
  • 2015年08月07日 09:45
  • 2586

java中全角半角字符的相互转换

package com.whatycms.common.util; import org.apache.commons.lang.StringUtils; /** * * 提供对字符串的全角...

C#全角和半角转换的原因及方法

在计算机屏幕上,一个汉字要占两个英文字符的位置,人们把一个英文字符所占的位置称为"半角",相对地把一个汉字所占的位置称为"全角"。在汉字输入时,系统提供"半角"和"全角"两种不同的输入状态,但是对于英...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:java将日文半角片假名转成全角的方法
举报原因:
原因补充:

(最多只允许输入30个字)