CakePHP3のメッセージ日本語化の設定(国際化と地域化の機能の使い方の解説)
2019/08/16
CakePHP3の英語のメッセージを日本語に翻訳して表示する
CakePHP3にはメッセージを日本語化する機能が搭載されている
CakePHP3で、Bakeすることで自動生成されてくるプログラムや画面のテンプレート(HTMLファイル)に使われるメッセージの言語は英語です。
ですが、CakePHP3には、英語のメッセージを日本語化(多言語化)する機能があらかじめ搭載されていますので、それを利用して日本語化(多言語化)する方法を解説します。
具体的には、「/src/Locale/ja/」フォルダを作成し、その中に「default.po」という英語を日本語に翻訳する翻訳ファイルを設置すると、英語のメッセージを日本語に翻訳して表示してくれます。
翻訳の仕組みはシンプルなのですが、翻訳ファイル「default.po」を作成する作業は結構大変な作業なので、CakePHP3に用意されているツールを使って作成していきます。
CakePHP3に搭載されている日本語化(多言語化)の手順は以下のとおりです。
- 【コマンド実行】英語と日本語(他国語)を関連付ける辞書ファイルのベースを作成
- 【アナログ作業】辞書ファイルに英語に対応する日本語の対訳を編集する
- 【自動処理】画面表示時に、辞書ファイルにもとづき日本語を表示する
もう少し具体的に書くと
【コマンド実行】で「default.pot」ファイルを作成し
【アナログ作業】で「default.pot」ファイルを元に「default.po」ファイルを作成して、日本語の対訳を編集する
そうすると、
【自動処理】として、CakePHP3が画面を表示する際に、プログラムなどに記述されている英語のメッセージを「default.po」に書かれている日本語訳に置き換えて日本語のメッセージとして画面を表示してくれる
ということになります。
【コマンド実行】は、2、3分の作業。
【自動処理】は、自動処理なので特に何もしない。
ですが、【アナログ作業】の日本語の訳を付けていく作業は完全にアナログ作業ですので、メッセージ数が多ければ多いほど時間がかかります。
ただ、すべてのメッセージを日本語化する必要があるわけではありませんので、最低限対応が必要なところから順次進めていくといいのではないでしょうか。
それでは、以降が具体的な作業手順です。
CakePHP3でメッセージを日本語化(多言語化)するための手順の解説
辞書ファイルのベースを作成する作業
まず、辞書ファイルのベースを作成するためにコマンドを実行します。
コマンドを実行する際は、CakePHP3のアプリを作成しているルートフォルダに移動します。
1 |
$ cd /var/www/html/example.com |
続いて、コマンド「bin/cake i18n」を実行します。
その後は、画面の表示に応じて選択肢を入力していきます。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 |
$ bin/cake i18n I18n Shell --------------------------------------------------------------- [E]xtract POT file from sources [I]nitialize a language from POT file [H]elp [Q]uit What would you like to do? (E/I/H/Q) > E [←「E」を入力します。] Current paths: None What is the path you would like to extract? [Q]uit [D]one [/var/www/html/example.com/src/] > [←「Enter」を押します。] Current paths: /var/www/html/example.com/src/ What is the path you would like to extract? [Q]uit [D]one [D] > [←「Enter」を押します。] Would you like to extract the messages from the CakePHP core? (y/n) [n] > y [←「y」を押します。] What is the path you would like to output? [Q]uit [/var/www/html/example.com/src/Locale] > [←「Enter」を押します。] Would you like to merge all domain strings into the default.pot file? (y/n) [n] > y [←「y」を押します。] Extracting... --------------------------------------------------------------- Paths: /var/www/html/example.com/src/ /var/www/html/example.com/vendor/cakephp/cakephp/src/ Output Directory: /var/www/html/example.com/src/Locale/ --------------------------------------------------------------- ==========================================================================> 100% Done. --------------------------------------------------------------- I18n Shell --------------------------------------------------------------- [E]xtract POT file from sources [I]nitialize a language from POT file [H]elp [Q]uit What would you like to do? (E/I/H/Q) > q [←「q」を押します。] |
最後まで実行すると、「/var/www/html/example.com/src/Locale/」に、辞書ファイル「default.pot」が生成されていますので、それを確認します。
コマンドを「bin/cake i18n extract」と入力する方法もある
今回はコマンド「bin/cake i18n」を実行していますが、「bin/cake i18n extract」と入力する方法もあります。
今回は、コマンド「bin/cake i18n」を実行し、表示されるメニューの中から「E(extract)」を選択していますが、最初に入力するコマンドを「bin/cake i18n extract」とすることで、はじめから「E」を選択した状態まで進めることができます。(1工程だけスキップすることができます。)
1 |
$ bin/cake i18n extract |
また、コマンド「bin/cake i18n」を実行したときにでてくるメニューはそれぞれ以下の内容になります。
1 2 3 4 5 6 7 8 9 10 11 |
[E]xtract POT file from sources →ソースファイルから POTファイルを抽出する [I]nitialize a language from POT file →POTファイルから言語を初期化する [H]elp →ヘルプ [Q]uit →終了 |
default.potがある場合は上書きをするかどうかの確認が追加される
すでに「/var/www/html/example.com/src/Locale/default.pot」ファイルが存在する場合は、下記の確認が追加されます。
上書きする場合は「y」を選択します。
もし、すでに日本語化したファイルがある場合は、「default.pot」のファイル名を変更するなどして対応してください。
1 2 3 4 5 6 7 8 9 10 11 12 13 |
略 : ==========================================================================> 100% Error: default.pot already exists in this location. Overwrite? [Y]es, [N]o, [A]ll (y/n/a) [y] > y [←「y」を押します。] 134 marker error(s) detected. => Use the --marker-error option to display errors. Done. --------------------------------------------------------------- I18n Shell : 略 |
生成された辞書のベースファイルの確認
コマンド「bin/cake i18n」を実行すると、「/var/www/html/example.com/src/Locale/」に、辞書ファイル「default.pot」が生成されていますので、それを確認します。
生成されているファイルは、以下のような内容です。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 |
# LANGUAGE translation of CakePHP Application # Copyright YEAR NAME <EMAIL@ADDRESS> # #, fuzzy msgid "" msgstr "" "Project-Id-Version: PROJECT VERSION\n" "POT-Creation-Date: 2019-03-30 19:20+0900\n" "PO-Revision-Date: YYYY-mm-DD HH:MM+ZZZZ\n" "Last-Translator: NAME <EMAIL@ADDRESS>\n" "Language-Team: LANGUAGE <EMAIL@ADDRESS>\n" "MIME-Version: 1.0\n" "Content-Type: text/plain; charset=utf-8\n" "Content-Transfer-Encoding: 8bit\n" "Plural-Forms: nplurals=INTEGER; plural=EXPRESSION;\n" #: Controller/TopicsController.php:68;178 msgid "The topic has been saved." msgstr "" #: Controller/TopicsController.php:72;190 msgid "The topic could not be saved. Please, try again." msgstr "" #: Controller/TopicsController.php:207 msgid "The topic has been deleted." msgstr "" #: Controller/TopicsController.php:209 msgid "The topic could not be deleted. Please, try again." msgstr "" #: Template/Layout/TwitterBootstrap/dashboard.ctp:101 msgid "ホーム" msgstr "" #: Template/Layout/TwitterBootstrap/dashboard.ctp:102 msgid "使い方" msgstr "" #: Template/Layout/TwitterBootstrap/dashboard.ctp:103 msgid "お知らせ" msgstr "" : : 略 |
このファイルは、辞書ファイルのベースとなるもので、コントローラーやテンプレートファイルの中にある「__('*****')
」の部分を抽出したものになります。
msgid "The topic has been saved."
の部分がテンプレートに記載がある英語表記のメッセージ部分で
msgstr ""
の部分が、これから日本語に翻訳したメッセージを編集する部分です。
上記の「ホーム」「使い方」「お知らせ」などは日本語が出力されていますが、それは、すでにテンプレートファイルにある「__('*****')
」の部分を日本語に置き換えているためです。
翻訳ファイルを作成するのであれば、日本語にした箇所があるあ場合は、英語に戻した上で、改めて翻訳ファイルを作成し直すほうがいいでしょう。
また、コマンドで作成した「default.pot(default.po)」ファイルの「msgid ""
」「msgstr ""
」ですが、手作業でメッセージを追加していっても全く問題ありません。
翻訳ファイルのベースファイルを日本語対応のファイルに変換する
翻訳のベースファイル(default.pot)を、日本語対応のファイルに変換します。
1.日本語辞書を入れるフォルダを作成する
まず、日本語の辞書を入れるフォルダを作成します。
「default.pot」ファイルが生成されている
/src/Locale/
フォルダの中に「ja」フォルダ(もしくは、「ja_JP」フォルダ)を作成します。
また、日本語以外では「フランス語:fr」「ドイツ語:de」「ロシア語:ru」「イタリア語:it」などのフォルダを作成します。
2.日本語辞書ファイルを設置する
前項で作成した「ja」フォルダの中に、作成された「default.pot」を「default.po」にファイル名を変更して設置します。(拡張子を「.pot」から「.po」に変更します。)
これで設置完了です。
3.実際に日本語に変換されるかを確認する
前項で、設置は完了ですが、この状態では英語の翻訳となる日本語の編集をしていませんので、日本語は表示されません。
そのため、辞書ファイルの中の分かりやすい「Submit」などを日本語に変換してみて、画面をリロードして、日本語に変わることを確認してみてください。
翻訳ファイルを修正したときはキャッシュをクリア
翻訳ファイルを設定すると翻訳した内容はキャッシュされる場合が多々あります。
そのため、翻訳ファイルを変更したのに反映されない、ということが起こりますので、翻訳ファイルを変更した場合はその都度キャッシュをクリアすることをオススメします。
キャッシュのクリア方法は、ルートフォルダでコマンド「bin/cake cache clear_all」を実行する方法が一番簡単で確実です。
詳しくは、下記の記事を参照してください。
CakePHP3、CakePHP4のキャッシュをクリアする方法「bin/cake cache clear_all」を使う
コマンド「bin/cake i18n」実行時に発生するエラー内容の確認方法
コマンド「bin/cake i18n」を実行して、テンプレートを作成する時にエラーが発生すると、下記のようなエラーメッセージを見ることがあります。
7 marker error(s) detected.
=> Use the --marker-error option to display errors.
この場合は、エラーメッセージを表示する場合は下記の通りコマンドを実行し、再度辞書ファイルを作成すると詳細なエラーメッセージが表示されます。
1 |
$ bin/cake i18n extract --marker-error |
エラーメッセージを見ながらエラーの原因になっている箇所を修正していくといいでしょう。
翻訳ファイルを反映させる方法・翻訳対象のメッセージを作成する方法
翻訳ファイルを反映させる方法
前項の作業を行い、日本語の翻訳ファイルを設置して画面をリロードすると日本語が表示されたと思います。
これは、日本語の端末を使っていますので、CakePHP3が言語を判断し、それに合う日本語の辞書ファイルを適用し、日本語を表示させたためです。
英語の端末でアクセスをすると、英語表記のままになります。
ですが、アクセスする端末によらず、強制的に日本語で表示したい、という場合もあるでしょう。
そういう場合の設定方法を解説します。
/config/app.php に指定をする方法
/config/app.phpに指定する方法があります。
app.phpの 40行目あたりから、CakePHP3の基本的な設定情報を記述する箇所があります。
この中にある「APP_DEFAULT_LOCALE」を「en_US」から「ja_JP」に変更します。
1 2 |
// 'defaultLocale' => env('APP_DEFAULT_LOCALE', 'en_US'), 'defaultLocale' => env('APP_DEFAULT_LOCALE', 'ja_JP'), |
設定情報は、「app.php」ではなく、「/config/.env」を利用して設定している場合は、「.env」ファイルの中にある「APP_DEFAULT_LOCALE」を変更します。
1 2 |
//export APP_DEFAULT_LOCALE="en_US" export APP_DEFAULT_LOCALE="ja_JP" |
コントローラーに指定をする方法
サイト全体ではなく、コントローラーやアクション単位で日本語化したい場合は下記のようにコントローラーに記述することでコントローラー単位で設定をすることもできます。
下記の 7行目、15行目の処理を追記します。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 |
<?php namespace App\Controller; use App\Controller\AppController; // I18n を指定 use Cake\I18n\I18n; class UsersController extends AppController { public function index() { // 日本語化の指定 I18n::setLocale('ja_JP'); } } |
翻訳対象のメッセージを作成する方法
先に「__('*****')
」の部分を翻訳ファイルに抽出します、と書きましたが、この翻訳対象とするメッセージの記述方法を紹介します。
「__('*****')
」は完全一致で翻訳
翻訳対象のメッセージを設定する基本的な記述方法です。
1 |
<?= __('Add Topic') ?> |
上記の「__('*****')
」形式で記述した場合は、翻訳ファイルにある「msgid “”」のテキストと完全一致した場合に対応する翻訳テキストが表示されます。
一致するものがない場合は、英語の表記がそのまま表示されます。
「__d('*****','*****')
」は機能、プラグインごとに翻訳ファイルを分割
機能やプラグインごとに翻訳ファイルを分割したい場合は、下記のように「__d('*****','*****')
」形式で記述します。
1 |
<?= __d('test_plugins', 'Add User') ?> |
この場合、「/src/Locale/{言語フォルダ}/test_plugins.po」を翻訳ファイルとして読み込みます。
「__x('*****','*****')
」は識別子で翻訳を振り分け
例えば、同じ「Submit」でも、登録画面では「登録実行」、更新画面では「更新実行」と翻訳を当てたい場合は、下記のように「__x('*****','*****')
」形式で記述します。
1 2 3 4 5 |
// 「登録実行」を編集 <?= __x('add', 'Submit') ?> // 「更新実行」を編集 <?= __x('edit', 'Submit') ?> |
1 2 3 4 5 6 7 |
msgctxt "add" msgid "Submit" msgstr "登録実行" msgctxt "edit" msgid "Submit" msgstr "更新実行" |
動的な値をメッセージに含める場合
メッセージは固定の内容だけではなく、プログラムから取得する動的な値をメッセージに含めたい場合もあるでしょう。
そういう場合に動的にメッセージを入れる方法も用意されています。
まず、プログラムなどに記述するメッセージの方は、下記のように 1つ目のパラメータにプレースホルダー({0}
)付きのメッセージを記述します。
2つ目のパラメーターには実際に編集する文字列を配列で指定します。
1 2 3 |
$place = "zoo"; $food = "hot dog"; <?= __("I want to go to the {0}. I want to eat a {1}.", [$place, $food]) ?> |
上記の例では、「$place」「$food」の変数の値がプログラムで置き換える動的な値の部分です。
そして、翻訳ファイルのようには、下記のようにプレースホルダー付きのメッセージを翻訳するものと、動的に置き換えられるメッセージの翻訳したものとを記載していきます。
このようにしておくことで、動的に編集されるメッセージも日本語に翻訳されて画面に表示されます。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 |
msgid "I want to go to the {0}. I want to eat a {1}." msgstr "私は {0} に行きたい。私は {1} を食べたい。" msgid "zoo" msgstr "動物園" msgid "aquarium" msgstr "水族館" msgid "hot dog" msgstr "ホットドッグ" msgid "sushi" msgstr "寿司" msgid "pizza" msgstr "ピザ" |
メッセージの中に「’(シングルクォート)」「”(ダブルクオート)」がある場合のエスケープ
例えば、「I don’t know.」という文章がある場合、「’(シングルクォート)」をどうしたらいいのか、と疑問に思う場合もあるかもしれません。
これらの場合は、PHPの基本的な処理と同様に「\」を使ってエスケープするか、「”(ダブルクオート)」で囲めば OKです。
1 2 3 4 5 6 7 |
// 「"(ダブルクオート)」 msgid "I don't know." msgstr "私は知りません。" // 「'(シングルクォート)」 msgid 'I don\'t know.' msgstr '私は知りません。' |
「msgid」「msgstr」のパラメーターの指定は、「’」「”」のどちらでも問題ありませんので、メッセージの中に含まれる「’」「”」に合わせて変える、という方法でもいいのではないか、と思います。
プログラム規約で「’」に決まっている、という場合などはエスケープ処理をするといいでしょう。
ユーザ管理・ログイン認証プラグイン「CakeDC/Users」の日本語化
ユーザ管理・ログイン認証プラグインである「CakeDC/Users」の辞書ファイルは、プラグインとして別に持っています。
その CakeDC/Usersが持っている辞書ファイルを編集する方法については下記の記事を参考にしてください。
CakePHP3のプラグイン「CakeDC/Users」を日本語化・翻訳ファイルもダウンロード可
翻訳ファイル作成エディタ「Poedit」
CakePHP3 と WordPressとでは日本語化対応のための仕組みはやや異なりますが、WordPressには日本語の翻訳ファイルを作成するための便利なツール「Poedit」があります。
Poedit オフィシャルサイト
https://poedit.net/
翻訳するときに日本語訳の例示を出してくれたり、何割の翻訳が終わっているかを表示してくれたりと、翻訳作業がはかどりやすくなるツールです。
CakePHP3では WordPressで使用する「.mo」ファイルの生成は必要ありませんが、CakePHP3の翻訳でも役に立ちますので、こういったツールを利用してみるのもいいでしょう。
下記の記事は WordPressの日本語化についての記事ですが、「Poedit」や「.pot」「.po」「.mo」ファイルについても書いていますので、あわせて参考にしてください。
PoeditでWordPressの日本語対応方法。英語プラグインの日本語翻訳ファイル作成
CakePHP3の関連記事
CakePHP4のCSS、JavaScript、画像のブラウザへのキャッシュをコントロールするCakePHP3でレコードを保存(追加、更新、Insert、Update)する複数の方法を紹介
CakePHP3でモデルなしフォームからCSVをアップロードしレコードを更新する方法解説
CakePHP3でPHP Simple HTML DOM Parserを使ってスクレイピングする方法
CakePHP3のInsert On Duplicate Key Update(upsert)構文を解説・バルク処理も
CakePHP3の1対多での連携を中間テーブルを使った多対多の連携に変更するときの手順
CakePHP3でデフォルトのソート条件を設定してユーザの選択肢たソート条件を有効にする方法
CakePHP3で Ajaxを使う方法の解説。3.6以降対応。Successとthenの両方を解説。
CakePHP3でパンくずの指定は HTMLヘルパーを使って指定する方法を解説
CakePHP3にOGPをfetch、asignを利用してテンプレートごとに指定する方法を解説
その他の「CakePHP3」に関する記事一覧
この記事が参考になったと思いましたらソーシャルメディアで共有していただけると嬉しいです!
関連記事
-
CakePHP2の検索Plugin CakeDC/Searchで重複を省くgroup by(distinct)の実装方法
CakePHP2の検索プラグイン「CakeDC/Search」で、重複レコードを省くgroup by、distinctを使う方法についての解説。設定する場所はpaginatorの条件とするので、find()関数と同じ。
-
CakePHP3にデイトピッカー jQuery UI DatePickerを実装する手順の解説
CakePHP3にjQuery UIのDatePickerを実装する手順を説明。併せて、デイトピッカーを設置に関連するCakePHP3の解説と、テーマを変更したり、表記を変更するカスタマイズする方法なども紹介。
-
CakePHP3のcontroller内でテンプレート、レイアウトを変更する際の指定方法
CakePHP3でテンプレートファイルやレイアウトファイルをデフォルトのものから別のものに変更したい場合の指定方法を解説。
-
CakePHP3の検索プラグイン「friendsofcake/search」の様々な検索の仕方の実装方法
CakePHP3で検索をするプラグイン「friendsofcake/search」の検索条件のカスタマイズ方法の解説。検索項目を増やしたり、以上、以下での検索や、チェックボックスによる検索の方法などを解説。
-
CakePHP3のタイムゾーンを協定世界時UTCから日本標準時間JSTにずれを変更する方法
CakePHP3の標準設定のタイムゾーンは「UTC(協定世界時)」に設定されている。これを日本標準時に変更する方法(app.php、bootstrap.phpの変更方法)の解説。
-
CakePHP3でデータを保存する save()で発生するエラーを確認する方法を解説
CakePHP3でデータ保存処理のログを取得する方法。save()では true、falseの戻り値しか取得できないが、saveOrFail()と try…catch文を使いエラーログ、エンティティを取得し、不具合の解析を行う。
-
CakePHP3で /Layout/defult.ctpにある titleタグ、h1タグを編集する方法
CakePHP3でtitleタグ、h1タグのテキストをデフォルトから変更する方法を解説。テンプレートファイルに「$this->assign()」でテキストを指定して「/Layout/defult.ctp」で受け取る。
-
CakePHP 2.3でファイルをアップロード・その2 ファイル名を乱数で設定
CakePHPのアップロードするファイル名を乱数で変更しセキュリティを高める方法を解説。
-
CakePHP3のビューで受取ったテーブルのオブジェクトを連想配列に変換する方法
コントローラーからビューに送ったテーブルのオブジェクトを連想配列に変換し、ビューの中で自由に使えるようにするメソッド「toArray()」の解説。連想配列に変換できれば利用度アップ!
-
CakePHP4 のコマンドプログラムからコンポーネントを読み込む方法解説
CakePHP4でコマンドプログラムからコンポーネントを呼び出す方法を解説。コントローラーから呼び出すときと大差はないが、use句でコンポーネントを指定する事がポイント。