技術屋の宿命として、英文ドキュメントの読解がありますが、和文があればそれに越したことはありません。
最近は英文を機械翻訳で和文提供しているサイトもありますので、機械翻訳を使ってPDF化されている英文文書を翻訳することにチャレンジしてみました。
■契機
2010から2016のオフィスに切り替わった時に、wordがPDFファイルを結構賢くword文書に変換できることを知りました。
また、wordには名前を付けて保存するときに、様々な形式の文書に変換することができ、その中にhtmlも含まれていることから、その結果をgoogle翻訳で和訳すればうまくいくのではないかと考えました。
■懸念点
やるにあたっては色々心配な点がありました。
・PDFからWordが取り込んだ結果は使える品質か
・Wordが保存したhtmlは使い物になのか
・Google翻訳がローカルに保存されているhtmlファイルに適用できるのか
などなど
■結果
最終的にはPDF(英文)をhtml(和文 or 英文+翻訳)という形が実現できました。
■手順
作業は次の手順となります。
- PDFをWordで開く
- html形式で保存する
- 英文htmlの内容を和訳する
- 生成された結果の補正
ほぼWordに任せておけるのですが、一部のWordの不可解な振る舞いのため、手順4が必要になりました。
■例
仕事柄UMLとの付き合いが多いので、今回はUML2.5の最新ドキュメントを和訳してみましたので、その時の作業を例として示します。
UMLのドキュメントはOMGのサイトから入手します。
□手順1 PDFをWordで開く
PDFドキュメントformal-15-03-01.pdfをWordの「開く」機能で開きます。開くときには次のような確認が表示されます。。
確かに読み込みには結構時間がかかります。自分の環境では1分15秒ほどかかりました。
今回自分が欲しかったのは15 Activitiesだったので、この後の作業時間の短縮のために、必要なページだけを新しいPDFファイル"UML2.5-15 Activities.pdf"として切り出しました。これだと開くのに7秒でした。
読み込んだ結果を見ると、かなり良く内容が解析されていることがわかります。
・見出しが識別されてスタイル設定されている
・図がイメージとして取り込まれている
この結果をみると、WordでPDFを取り込むことで、翻訳だけではなくPDF文書のデータ解析もかなりできそうな気がしてきます。
□手順2 html形式で保存する
「ファイル」「名前を付けて保存」を実行します。
「名前を付けて保存」ダイアログの「ファイルの種類(T)」で「Webページ(.htm;.html)」を選択します。
後はファイルの名前を入力して実行します。
うまくいくと、指定した名前のファイルとファイル名と同じ名前のサブフォルダが作成されます。
サブフォルダの中身を見ると、文書に含まれていたイメージファイルが保存されていることがわかります。
□手順3 英文htmlの内容を和訳する
これはとてもあっけないものでした。Chromeを使って生成されたhtmファイルを開くと次のように翻訳の問い合わせが登場します。
「翻訳」を選択すると、表示されている英文が和文に変換されます。
表示されていない範囲は翻訳されないので、翻訳応答はとても早いです。
隠れている文書を表示させると、順次翻訳されていきます。
ここで気になる点が2つあります。
- 画像イメージがWordに表示されていた時の内容よりも粗い
- 翻訳前の原文を、文書単位に表示できない
2は今回の目的とは直接関係ないので、追うのはまたの機会にするとして、1についてはこのままでは翻訳ができても読むのに品質が不適切なので何とかしたいところです。
□手順4 生成された結果の補正
手順3で発見された問題点の対策をするため、生成されたファイルを調べてみたところ、次のことがわかりました。
- htm保存時に作成されたサブフォルダには、画質の良いものと粗い物が存在する。
- 1のファイルはhtmの中からどちらも参照するタグが存在しているが、なぜか良い画質の画像を使うタグがコメントアウトされている
※image001.pngが良い画質の画像で、image002.gifが粗い画像
良質の画像と粗い画像は条件によって使い分けるような記述がしてあるのですが、良質の画像を使うタグはコメントになっているので、このファイルを直接修正しない限り、画質の改善はできません。
一通り調べてみると、良質の画像と粗い画像は
<良質の画像を表示するタグ>
<粗い画質の画像を表示するタグ>
というパターンになっているようでした。
試しに粗い画質の画像ファイル名を良い画質のファイル名に置換してみたところ、問題なく表示されました。
そこで、<粗い画像の画像を表示するタグ>のファイル名を<良質の画像を表示するタグ>に記載されているファイル名で置換することにします。
作業はPythonあたりでコードを書くのもありかもしれませんが、最近のテキストエディタは正規表現置換も完備されているので、フリーで使えるテキストエディタの正規表現置換機能を使って作業しようと思います。
いつも使っているサクラエディタをにも正規表現置換機能があるので、それで・・・と思ったのですが、一つ罠がありました。
今回置換しようとしているテキストは複数行にわたっているため、検索パターンを複数行に適用する必要があるのですが、サクラエディタではそれができませんでした。
そこで急遽希望に合う機能を持つフリーのテキストエディタを探した結果、Sublime Textにたどり着きました。英語版のソフトですが日本語にも対応可能なようです。しかし、今回はテキスト置換機能が欲しいだけなので、その点には触れません。
次の置換パターンを使って実施します。
【検索】(