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) > -1) { 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) > -1) { 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")); } }
原文:https://www.cnblogs.com/diehuacanmeng/p/13952267.html