7
6

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 1 year has passed since last update.

【GoogleAppsScript/Google Slide】DeepL を使ってプレゼンを一括で翻訳する

Last updated at Posted at 2021-11-07

翻訳するの、めんどくさくない?

限界サラリーマンであれば一回くらいは 「これ翻訳しといて」 みたいな雑な依頼来ますよね。
「それワイの仕事じゃなくない・・・?」 みたいな仕事でも、やらざるを得ないのが限界サラリーマン。

私の場合は英語で作られたパワーポイント(google slide)を和訳しないと行けない仕事があり、泣く泣くDeepLを叩いては翻訳をコピペしていく作業を行おうと思っていたのですが、よく考えたらGASでプレゼン全体をgoogle翻訳出来るなに始まり、調べたらDeepL APIが500,000字/月まで無料だったのがわかったため、ならdeepLでスライド全部翻訳したらええやんと思い立ったのでスクリプトにしてみました。

プレゼン以外にも、google documentでもspreadsheetでも活用できそうですね。
限界サラリーマンの他にも、限界大学院生、ドクター、研究者のみなさんの手助けになることも祈っております。

なお記事執筆にあたり、下記のQiita、Note記事を参照にしております。

参考サイト

A【GoogleAppsScript】GASでDeepL APIを叩く
B DeepL API を使ってみる
C【GAS】Google Apps Script 活用事例 Google Slides全ページを、一瞬で英語訳する。

準備・使い方

①DeepLでアカウントをとって、API KEYを取得します。ココらへんは上記リンクA、Bを見てもらうとわかりやすいです。
https://script.google.com/home からスタンドアロンのGASファイルを作成。
③新しいスクリプトが立ち上がったらサービスでSildesを追加。宗教上の理由でDeepLが使えない方はLanguageApp(google翻訳)を追加しましょう
image.png
④下記のスクリプトをコピペして貼り付け。
⑤deepLのAPIキーとスライドIDをコピペして下記<>書き欄のところに貼り付け。
⑥translateWholeSlideを実行。
⑦おしまい!

中身

translater.gas
const slideId="<翻訳したいスライドのID>"
  
//スライド全体を英語に翻訳する
function translateWholeSlide() {
  let presentation = SlidesApp.openById(slideId);
  let slides = presentation.getSlides();


  for (let i = 0; i < slides.length; i++) {
    let thisShapes = slides[i].getShapes()
    let preTranslateText = ""//念の為、翻訳前のテキストをスピーカーノートに書いておく

    thisShapes.map((value, index) => {
      let text = value.getText().asString()

      if (text.trim() !== "") {//オブジェクトにテキストがなければスキップ
        //let translatedText = LanguageApp.translate(text, 'en', 'ja');//deepL APIが使えない場合はGoogle 翻訳で
        let translatedText =deepltranslate(text, 'en', 'ja');//英語から日本語に。(text, 'ja','en')なら日本語から英語に。
        value.getText().setText(translatedText);//翻訳されたテキストを、翻訳元のtextが入っていたShapeに入れる

        preTranslateText += `Object(${index}) : ${text} \n`
      }
    })
    let speakerNote = slides[i].getNotesPage().getSpeakerNotesShape().getText()   //スピーカーノートの取得 
    speakerNote.appendText("\n" + preTranslateText)//翻訳前のテキストをスピーカノートに追加する
  }
}
deepL.gas
//以下ほぼリンク②に記載のスクリプトのパクリ
const apiKey = '<取得したAPIキー>';
const apiUrl = 'https://api-free.deepl.com/v2/translate';

function deepltranslate(text, src, tgt) {
  let t = text.toString();
  let content = encodeURI(`auth_key=${apiKey}&text=${t}&source_lang=${src}&target_lang=${tgt}`);

  const postheader = {
    "accept":"gzip, */*",
    "timeout":"20000",
    "Content-Type":"application/x-www-form-urlencoded"
  }  

  const parameters = {
    "method": "post",
    "headers": postheader,
    'payload': content
  }

  try {
    let response = UrlFetchApp.fetch(apiUrl, parameters);
  }
  catch (e) {
    Logger.log(e.toString());return 'DeepL:Exception';
  }

  let response_code = response.getResponseCode().toString();
  if (response_code != 200) return `DeepL:HTTP Error(${response_code})`
      
  let json = JSON.parse(response.getContentText('UTF-8'));// JSONからテキストを取り出す
  return json.translations[0].text;
}

最後に

・どちらかというと日本語のスライドを英語圏むけの人向けに英訳するときのほうが使いみち多そう。
・deepL API無料分は500,000字/月だけど調子乗ってたらすぐ使い切りそう。
・Google SlideはあまりGASでいじっている人が多くなさそうだから、もっといろんな使いみちがありそう。

大学の頃、ゲロ吐きそうな顔しながら電子辞書ポチポチしてたのに比べたら楽な世の中になったな~~~!なんて思いました。
ほなまたな!

7
6
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
7
6

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?