[JavaScript] 全角⇔半角の変換を行う(英数字、カタカナ)
数字、アルファベット、カタカナの全角半角変換は、JavaScriptで簡単に実現できます。今日はその実装方法をブログに書きたいと思います。
また、処理範囲を正規表現で
全角→半角と同様に、正規表現の
上記の対応表以外にも対応したい文字があれば、マッピングに追加することで、処理対象に加えることができます。
なお、カタカナの全角半角の変換ルールは、プロジェクトやアプリケーションによって異なる場合があるので、上記と違う場合にはそれに応じて対応表を書き直す必要があります。
最後になりますが本ブログでは、フロントエンド、Python、インフラ、サーバー、PHP、Swift、Node.js、Java、Linux、機械学習、などの技術トピックを発信をしていきます。「プログラミングで困ったその時の、解決の糸口に!」そんな目標でブログを書き続けています。ぜひ、本ブログのRSSやTwitterをフォローして貰えたら嬉しいです ^ ^
最後までご覧頂きましてありがとうございました!
目次
全角 → 半角(英数字)
function hankaku2Zenkaku(str) { return str.replace(/[A-Za-z0-9]/g, function(s) { return String.fromCharCode(s.charCodeAt(0) - 0xFEE0); }); } // 使用例 hankaku2Zenkaku('123abC'); // '123abC'文字コード上で、全角英数字から
65248
引くと半角英数字になります。また、処理範囲を正規表現で
[A-Za-z0-9]
と指定していますが、例えば[0-9]
とすれば、変換対象を全角数字に限定できます。半角 → 全角(英数字)
function zenkaku2Hankaku(str) { return str.replace(/[A-Za-z0-9]/g, function(s) { return String.fromCharCode(s.charCodeAt(0) + 0xFEE0); }); } // 使用例 zenkaku2Hankaku('123abC'); // '123abC'全角→半角とは逆で、半角英数字に
65248
加えると全角英数字になります。全角→半角と同様に、正規表現の
[A-Za-z0-9]
を変更することで、処理対象を限定できます。全角 → 半角(カタカナ)
カタカナの場合、文字コードの演算ではうまくできない部分があるので、マッピングを作成して対応します。function zenkana2Hankana(str) { var kanaMap = { "ガ": "ガ", "ギ": "ギ", "グ": "グ", "ゲ": "ゲ", "ゴ": "ゴ", "ザ": "ザ", "ジ": "ジ", "ズ": "ズ", "ゼ": "ゼ", "ゾ": "ゾ", "ダ": "ダ", "ヂ": "ヂ", "ヅ": "ヅ", "デ": "デ", "ド": "ド", "バ": "バ", "ビ": "ビ", "ブ": "ブ", "ベ": "ベ", "ボ": "ボ", "パ": "パ", "ピ": "ピ", "プ": "プ", "ペ": "ペ", "ポ": "ポ", "ヴ": "ヴ", "ヷ": "ヷ", "ヺ": "ヺ", "ア": "ア", "イ": "イ", "ウ": "ウ", "エ": "エ", "オ": "オ", "カ": "カ", "キ": "キ", "ク": "ク", "ケ": "ケ", "コ": "コ", "サ": "サ", "シ": "シ", "ス": "ス", "セ": "セ", "ソ": "ソ", "タ": "タ", "チ": "チ", "ツ": "ツ", "テ": "テ", "ト": "ト", "ナ": "ナ", "ニ": "ニ", "ヌ": "ヌ", "ネ": "ネ", "ノ": "ノ", "ハ": "ハ", "ヒ": "ヒ", "フ": "フ", "ヘ": "ヘ", "ホ": "ホ", "マ": "マ", "ミ": "ミ", "ム": "ム", "メ": "メ", "モ": "モ", "ヤ": "ヤ", "ユ": "ユ", "ヨ": "ヨ", "ラ": "ラ", "リ": "リ", "ル": "ル", "レ": "レ", "ロ": "ロ", "ワ": "ワ", "ヲ": "ヲ", "ン": "ン", "ァ": "ァ", "ィ": "ィ", "ゥ": "ゥ", "ェ": "ェ", "ォ": "ォ", "ッ": "ッ", "ャ": "ャ", "ュ": "ュ", "ョ": "ョ", "。": "。", "、": "、", "ー": "ー", "「": "「", "」": "」", "・": "・" } var reg = new RegExp('(' + Object.keys(kanaMap).join('|') + ')', 'g'); return str .replace(reg, function (match) { return kanaMap[match]; }) .replace(/゛/g, '゙') .replace(/゜/g, '゚'); }; // 使用例 zenkana2Hankana('アシタハイイテンキカナ、ブーヴー'); // 'アシタハイイテンキカナ、ブーヴー'対応表に沿って、該当する文字を1つずつ変換しています。
上記の対応表以外にも対応したい文字があれば、マッピングに追加することで、処理対象に加えることができます。
半角 → 全角(カタカナ)
同じく、対応表(マッピング)を作成して対応します。function hankana2Zenkana(str) { var kanaMap = { 'ガ': 'ガ', 'ギ': 'ギ', 'グ': 'グ', 'ゲ': 'ゲ', 'ゴ': 'ゴ', 'ザ': 'ザ', 'ジ': 'ジ', 'ズ': 'ズ', 'ゼ': 'ゼ', 'ゾ': 'ゾ', 'ダ': 'ダ', 'ヂ': 'ヂ', 'ヅ': 'ヅ', 'デ': 'デ', 'ド': 'ド', 'バ': 'バ', 'ビ': 'ビ', 'ブ': 'ブ', 'ベ': 'ベ', 'ボ': 'ボ', 'パ': 'パ', 'ピ': 'ピ', 'プ': 'プ', 'ペ': 'ペ', 'ポ': 'ポ', 'ヴ': 'ヴ', 'ヷ': 'ヷ', 'ヺ': 'ヺ', 'ア': 'ア', 'イ': 'イ', 'ウ': 'ウ', 'エ': 'エ', 'オ': 'オ', 'カ': 'カ', 'キ': 'キ', 'ク': 'ク', 'ケ': 'ケ', 'コ': 'コ', 'サ': 'サ', 'シ': 'シ', 'ス': 'ス', 'セ': 'セ', 'ソ': 'ソ', 'タ': 'タ', 'チ': 'チ', 'ツ': 'ツ', 'テ': 'テ', 'ト': 'ト', 'ナ': 'ナ', 'ニ': 'ニ', 'ヌ': 'ヌ', 'ネ': 'ネ', 'ノ': 'ノ', 'ハ': 'ハ', 'ヒ': 'ヒ', 'フ': 'フ', 'ヘ': 'ヘ', 'ホ': 'ホ', 'マ': 'マ', 'ミ': 'ミ', 'ム': 'ム', 'メ': 'メ', 'モ': 'モ', 'ヤ': 'ヤ', 'ユ': 'ユ', 'ヨ': 'ヨ', 'ラ': 'ラ', 'リ': 'リ', 'ル': 'ル', 'レ': 'レ', 'ロ': 'ロ', 'ワ': 'ワ', 'ヲ': 'ヲ', 'ン': 'ン', 'ァ': 'ァ', 'ィ': 'ィ', 'ゥ': 'ゥ', 'ェ': 'ェ', 'ォ': 'ォ', 'ッ': 'ッ', 'ャ': 'ャ', 'ュ': 'ュ', 'ョ': 'ョ', '。': '。', '、': '、', 'ー': 'ー', '「': '「', '」': '」', '・': '・' }; var reg = new RegExp('(' + Object.keys(kanaMap).join('|') + ')', 'g'); return str .replace(reg, function (match) { return kanaMap[match]; }) .replace(/゙/g, '゛') .replace(/゚/g, '゜'); }; // 使用例 hankana2Zenkana('アシタハイイテンキカナ、ブーヴー'); // 'アシタハイイテンキカナ、ブーヴー'こちらも同じく、変換処理に追加したい文字があれば、対応表に追加することで対応できます。
なお、カタカナの全角半角の変換ルールは、プロジェクトやアプリケーションによって異なる場合があるので、上記と違う場合にはそれに応じて対応表を書き直す必要があります。
関連記事
「[JavaScript] 全角カナ、半角カナの判定を行う方法」もブログに書きました。もし良ければ合わせてご覧ください。最後に
サービス開発をしていて、全角と半角の変換処理を扱う機会が何度かあったので、ノウハウとして残しておきたいと思いブログにしました。コピペして使えるようになっておくとコーディングスピードが上がるので良いかなと思います。最後になりますが本ブログでは、フロントエンド、Python、インフラ、サーバー、PHP、Swift、Node.js、Java、Linux、機械学習、などの技術トピックを発信をしていきます。「プログラミングで困ったその時の、解決の糸口に!」そんな目標でブログを書き続けています。ぜひ、本ブログのRSSやTwitterをフォローして貰えたら嬉しいです ^ ^
最後までご覧頂きましてありがとうございました!