File size: 12,378 Bytes
1a024b8 fb27b03 1a024b8 eac41fa 1a024b8 fb27b03 1a024b8 fb27b03 1a024b8 fb27b03 1a024b8 fb27b03 1a024b8 fb27b03 1a024b8 fb27b03 1a024b8 fb27b03 1a024b8 fb27b03 1a024b8 fb27b03 1a024b8 fb27b03 1a024b8 e70c3ee fb27b03 e70c3ee 1a024b8 fb27b03 1a024b8 fb27b03 1a024b8 e70c3ee fb27b03 e70c3ee 1a024b8 fb27b03 1a024b8 e70c3ee fb27b03 e70c3ee 1a024b8 fb27b03 e70c3ee 1a024b8 eac41fa 1a024b8 fb27b03 1a024b8 fb27b03 1a024b8 fb27b03 1a024b8 fb27b03 1a024b8 eac41fa 1a024b8 6b617d9 1a024b8 fb27b03 1a024b8 fb27b03 1a024b8 fb27b03 1a024b8 fb27b03 1a024b8 fb27b03 1a024b8 6b617d9 1a024b8 6b617d9 1a024b8 6b617d9 fb27b03 1a024b8 eac41fa 1a024b8 6b617d9 1a024b8 fb27b03 1a024b8 fb27b03 1a024b8 6b617d9 fb27b03 6b617d9 1a024b8 6b617d9 1a024b8 fb27b03 1a024b8 fb27b03 1a024b8 fb27b03 1a024b8 fb27b03 6b617d9 1a024b8 fb27b03 1a024b8 fb27b03 1a024b8 eac41fa 1a024b8 6b617d9 1a024b8 fb27b03 1a024b8 fb27b03 1a024b8 fb27b03 1a024b8 fb27b03 1a024b8 fb27b03 1a024b8 fb27b03 1a024b8 fb27b03 1a024b8 fb27b03 0eabd7a 1a024b8 e70c3ee 1a024b8 0eabd7a 1a024b8 fb27b03 1a024b8 6b617d9 1a024b8 eac41fa 6b617d9 3fb632b 1a024b8 fb27b03 1a024b8 fb27b03 1a024b8 eac41fa 1a024b8 0eabd7a 1a024b8 0eabd7a 1a024b8 0eabd7a 1a024b8 fb27b03 1a024b8 0eabd7a 1a024b8 e70c3ee 47ffc85 e70c3ee 1a024b8 eac41fa |
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 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 276 277 278 279 280 281 282 283 284 285 286 287 288 289 290 291 292 293 294 295 296 297 298 299 300 301 302 303 304 305 306 307 308 309 310 311 312 313 314 315 316 317 318 319 320 321 322 323 324 325 326 327 328 329 330 331 332 333 334 335 336 337 338 339 340 341 342 343 344 345 346 347 348 349 350 |
****************
deep_translator
****************
.. image:: https://img.shields.io/pypi/v/deep_translator.svg
:target: https://pypi.python.org/pypi/deep_translator
.. image:: https://img.shields.io/travis/nidhaloff/deep_translator.svg
:target: https://travis-ci.com/nidhaloff/deep_translator
.. image:: https://readthedocs.org/projects/deep-translator/badge/?version=latest
:target: https://deep-translator.readthedocs.io/en/latest/?badge=latest
:alt: Documentation Status
.. image:: https://img.shields.io/pypi/l/deep-translator
:target: https://pypi.python.org/pypi/deep_translator
.. image:: https://img.shields.io/pypi/dm/deep-translator
:target: https://pypi.python.org/pypi/deep_translator
.. image:: https://img.shields.io/pypi/status/deep-translator
:target: https://pypi.python.org/pypi/deep_translator
.. image:: https://img.shields.io/pypi/wheel/deep-translator
:target: https://pypi.python.org/pypi/deep_translator
.. image:: https://img.shields.io/github/last-commit/nidhaloff/gpx_converter
:alt: GitHub last commit
:target: https://pypi.python.org/pypi/deep_translator
.. image:: https://img.shields.io/twitter/url?url=https%3A%2F%2Ftwitter.com%2FNidhalBaccouri
:alt: Twitter URL
:target: https://twitter.com/NidhalBaccouri
.. image:: https://img.shields.io/badge/$-buy%20me%20a%20coffee-ff69b4.svg?style=social
:target: https://www.buymeacoffee.com/nidhaloff?new=1
=======================
自然言語の翻訳ツール
=======================
複数の翻訳サービスを使って、簡単な方法で異なる言語間で柔軟に翻訳を **無料** かつ **無制限** に行えるツールです
* フリーソフトウェア: MIT ライセンス
* ドキュメント: https://deep-translator.readthedocs.io.
==========
開発の動機
==========
Pythonを使用してテキストを別の言語に翻訳するタスクがありました。しかし、それを行う簡単な方法を見つけるのは困難でした。なぜなら、このタスクに適用できるライブラリはいくつか存在しますが、それらのほとんどはバグが多いか、無料ではないか、何らかの制約があるか、全ての言語をサポートしていないか、使用するのが簡単ではありませんでした。
そこで、このタスクを簡単に行えるツールを作成することにしました。100%無料で無制限で使いやすく、すべての言語をサポートしています。
このツールの目的は、複数の有名な翻訳サービスをこのツールに統合することにあります。
======================
使用例
======================
- Pythonを使用してテキストを翻訳したい場合
- ファイルのテキストを翻訳したい場合
- 1つだけでなく、多くのソースから翻訳結果を取得したい場合
- 翻訳を自動化したい場合
- 異なる翻訳結果を比較したい場合
- 言語を自動検出したい場合
======================
このツールの強み
======================
- 高度な抽象化が施されている
- 言語を自動で検出する
- 拡張と使用が簡単である
- 多くの翻訳サービスを統合して扱える唯一のpythonツールである
- 安定している
- 有名な翻訳サービスをサポートしている
========
機能
========
* google翻訳のサポート
* Pons (pons.com)のサポート
* Linguee のサポート
* Mymemory のサポート
* 自動言語検出
* テキストファイルから直接翻訳する
* 単語の複数の翻訳結果を取得する
* 異なる言語の異なる段落の翻訳を自動化する
* コマンドラインから直接翻訳する(バージョン1.1.0以上)
===============
インストール方法
===============
ツールの安定版をインストールする方法です:
.. code-block:: console
$ pip install -U deep_translator
ソースからインストールを行いたい場合、ドキュメントを参照してください。
=======
使い方
=======
このセクションでは、このツールで様々な統合トランスレータを利用するデモを行います。このデモでは、google、pons、linguee、mymemoryの翻訳サービスを扱います(現時点)。将来的には、より多くの翻訳サービスを統合する予定です。
==========
インポート
==========
.. code-block:: python
from deep_translator import (GoogleTranslator,
PonsTranslator,
LingueeTranslator,
MyMemoryTranslator,
detect_language)
サポートされている言語を確認する
============================
ポイント
関数get_supported_languagesを静的メソッドとして呼び出すことにより、各翻訳サービスでサポートしている言語を確認できます。
.. code-block:: python
# デフォルトではリストを返します
langs_list = GoogleTranslator.get_supported_languages() # output: [arabic, french, english etc...]
# 言語の省略形を辞書型にまとめて返すことも出来ます
langs_dict = GoogleTranslator.get_supported_languages(as_dict=True) # output: {arabic: ar, french: fr, english:en etc...}
言語検出
===================
ポイント
言語を自動的に検出することもできます。当然、このパッケージは無料です。言語検出機能を無料で使用する場合は、個人でapi_keyを取得する必要があります。ここで無料で入手することができます:https://detectlanguage.com/documentation
.. code-block:: python
lang = detect_language('bonjour la vie', api_key='your_api_key')
print(lang) # output: fr
Google 翻訳
=================
.. code-block:: python
text = 'happy coding'
- ソースの言語に自動検出を使用できます:
.. code-block:: python
translated = GoogleTranslator(source='auto', target='german').translate(text=text)
- ソースの言語の種類を指定することも出来ます:
.. code-block:: python
translated = GoogleTranslator(source='english', target='german').translate(text=text)
- 言語名は省略形で指定することも可能です:
.. code-block:: python
translated = GoogleTranslator(source='en', target='de').translate(text=text)
- ファイルから翻訳を行うことも出来ます:
.. code-block:: python
translated = GoogleTranslator(source='auto', target='german').translate_file('path/to/file')
- ソースの言語を検出し、望んだ言語に自動翻訳することが出来ます。
.. code-block:: python
# または、異なる言語の文章の翻訳を自動化したい時にも利用できます。
translated = GoogleTranslator(source='auto', target='de').translate_sentences([your_list_of_sentences])
PONS
===============
ポイント
Google翻訳同様に言語の名前を指定して翻訳することが出来ます。省略形で指定することも可能です。
.. code-block:: python
word = 'awesome'
- 簡単な翻訳方法
.. code-block:: python
translated_word = PonsTranslator(source='english', target='french').translate(word)
# 言語の省略形を指定する
translated_word = PonsTranslator(source='en', target='fr').translate(word)
- 全ての同義語か一致する単語を返す
.. code-block:: python
# 翻訳結果の全ての同義語を取得したい場合、引数にreturn_allにTrueを指定してください
translated_word = LingueeTranslator(source='english', target='french').translate(word, return_all=True)
Linguee
===================
.. code-block:: python
word = 'good'
- 簡単な翻訳方法
.. code-block:: python
translated_word = LingueeTranslator(source='english', target='french').translate(word)
# 言語の省略形を指定する
translated_word = LingueeTranslator(source='en', target='fr').translate(word)
- 全ての同義語か一致する単語を返す
.. code-block:: python
# 翻訳結果の全ての同義語を取得したい場合、引数にreturn_allにTrueを指定してください
translated_word = LingueeTranslator(source='english', target='french').translate(word, return_all=True)
Mymemory
====================
ポイント
sourceに"auto"を渡すことでmymemoryの自動言語検出を使用できます。
.. code-block:: python
text = 'Keep it up. You are awesome'
translated = MyMemoryTranslator(source='auto', target='french').translate(text)
ターミナルでの使用方法
====================
ターミナルからdeep_translatorをすぐに使用できます。使用するには、使用する翻訳サービス、翻訳元の言語、翻訳先の言語、翻訳するテキストなどを引数に指定する必要があります。
たとえば、Google翻訳を使用するには、引数として「google」を指定します。引数を変更することで、サポートされている他の翻訳サービスに切り替えることも可能です。ドキュメントを読んで、このツールでサポートされている翻訳サービスを確認してください。
.. code-block:: console
$ deep_translator --translator "google" --source "english" --target "german" --text "happy coding"
以下のように短く記述することもできます:
.. code-block:: console
$ deep_translator -trans "google" -src "english" -tg "german" -txt "happy coding"
翻訳元と翻訳先の言語を省略形で引数に指定することも出来ます。
.. code-block:: console
$ deep_translator -trans "google" -src "en" -tg "de" -txt "happy coding"
ヒント
==========
一般的に、google翻訳とmymemoryは文章に翻訳に適していますが、ponsとlingueeは単語の翻訳に適しています。
========
リンク
========
deep_translatorの使用目的やpythonで翻訳をする方法を確認するために以下のmediumの記事を確認してください。
https://medium.com/@nidhalbacc/how-to-translate-text-with-python-9d203139dcf5
===============================
スマートフォンアプリ Translator++
===============================
.. image:: ../../assets/app-icon.png
:width: 100
:alt: Icon of the app
deep_translatorを開発しみて、スマートフォンのアプリとして使用できれば便利なのではないかと思い立ちました。
google翻訳やpons、lingueeの個々のアプリは存在しますが、これらを統合して使用できるアプリを作れば便利ではないでしょうか。
それを出発点として、アプリの開発を開始しました。Pythonで作成しつつ、クロスプラットフォームのアプリを開発したかったので、`kivy フレームワーク <https://kivy.org/#home/>`_ を使用することにしました。
`Translator++ app <https://github.com/nidhaloff/deep-translator-app/>`_ もgithubでオープンソースとして公開しています。自由に編集やプルリクエストを行ってください;)
ポイント
Translator++はdeep_translatorパッケージがベースになっています。このアプリはパッケージの機能を試すために開発されています。
02-08-2020にGoogle Playで初公開されました。
スクリーンショット:
- スマートフォン :
.. image:: ../../assets/translator1.jpg
:width: 30%
:height: 200
:alt: screenshot1
.. image:: ../../assets/translator2.jpg
:width: 30%
:height: 200
:alt: screenshot2
.. image:: ../../assets/spinner.jpg
:width: 30%
:height: 200
:alt: spinner
- タブレット:
.. image:: ../../assets/hz_view.png
:width: 100%
:height: 300
:alt: screenshot3
=======================
次のステップに進むためには
=======================
詳細は examples フォルダを確認してください。
コントリビュートはいつでも歓迎しています。このパッケージが便利だと感じた方や使っている方がいたら、遠慮なくプルリクエストをしてフィードバックをください!
|