Pull to refresh

Автоматическое создание карточек слов для изучения иностранного языка или интеграция google translate в google sheets

Level of difficultyEasy
Reading time3 min
Views23K

Добрый день.

Недавно сделал инструмент автоматизированного создания карточек для изучения иностранных слов - подумал что может быть кому то пригодится и как инструмент, и как техническое решение.

Немного вводной информации: один из способов запоминания иностранных слов это создание карточек. На одной стороне слово пишется на родном языке, а на обратное стороне его перевод на нужный язык (на момент создания было доступно 103 языка). Также на карточке может быть дополнительная информация, например окончание для множественного числа слова.

Иногда для лучшего запоминания карточка содержит изображение слова, и в интернете большое количество готовых наборов карточек. Но, мне был нужен набор слов из учебника, который я использовал - в идеале любой скопированный текст. В принципе карточки можно сделать и руками, и конечно же это полезно для самого процесса изучения, но речь шла про несколько сотен слов с переводом на несколько языков (учусь в интернациональной группе).

пример отличных карточек для изучения иностранных слов
пример отличных карточек для изучения иностранных слов

Готового инструмента не нашел и решил написать свой. От картинок решил отказаться, хотя можно ИИ подключить :)

Писать отдельное приложение было лень, поэтому решил задачу с помощью Google Sheets и App Script.

Вот сам инструмент для создания карточек: https://docs.google.com/spreadsheets/d/1S5-9-eJf3yKaJ58Dgm7xUXbO3ceHpHWpupslSVcuv4M/edit?usp=sharing

Файл находится в режиме чтения, поэтому чтобы запустить скрипт нужно сделать копию файла. Вы можете скопировать на свой аккаунт этот файл с помощью пункта меню "File-Make copy" (также будет скопирован скрипт) и у вас будет возможность посмотреть сам код или внести изменения в Apps Script.

Кстати, текст из которого создаются слова может быть любым - скрипт создает список уникальных слов, так что повторений на карточках не будет. Т.е. слова специально готовить не нужно - просто вставить любой "копипаст" из интернета и через минуту список слов с переводом для двухсторонней печати будет готов.

Как это работает. В ячейку A2 нужно вставить текст (например из PDF версии учебника или любой текст из интернета). Далее в B2 и C2 выбрать язык текста и ваш родной язык для генерации перевода. Кнопка "Create Cards" запускает выполнение скрипта - скрипт потребует разрешение на доступ к документу Google Sheets из скрипта Apps Script.

Генерация перевода происходит с помощью API Google Translator. После 10 переводов скрипт делает паузу 1 секунду, иначе API Google Translator может выдавать ошибку и прекращать выполнение скрипта. В целом ограничение на 1 аккаунт вроде до 3000 слов в день.

var rowA = 1, rowB = 1;

var spreadsheetResult = spreadsheet.getSheetByName("Cards");

spreadsheetResult.clear();

  for (let i = 0; i < uniqueResult.length; i++) {

    var translatedWord = LanguageApp.translate(uniqueResult[i], sourceLang, targetLang);

      console.log(uniqueResult[i]);
      console.log(translatedWord)

    if (i % 2 === 0) { 
      spreadsheetResult.getRange(rowA, 1).setValue(uniqueResult[i]);
      spreadsheetResult.getRange(rowA, 4).setValue(translatedWord);
      rowA++;
    }
    else { 
      spreadsheetResult.getRange(rowB, 2).setValue(uniqueResult[i]);
      spreadsheetResult.getRange(rowB, 3).setValue(translatedWord);
      rowB++;
    }
    if (rowA % 10 === 0) {
        Utilities.sleep(1000) //pause 1 sec every 10 translations
    }
  }

На строке 29 добавил артикли для нескольких языков, чтобы перевод выводился вместе с артиклем - можете добавить артикли для вашего языка.

//add article of foreign language
  const targetWords = ['a', 'the', 'an',                                                //english
                        'le', 'la', 'les', 'un', 'une', 'des',                          //french
                        'der', 'die', 'das', 'den', 'dem', 'ein', 'eine', 'ein',        //german
                        'el', 'la', 'los', 'las', 'un', 'una', 'unos', 'unas',          //spanish
                        'il', 'lo', 'la', 'i', 'gli', 'le', 'un', 'uno', 'una', 'un'];  //italian

Итоговый список карточек генерируется на листе Cards - я его печатал в PDF и отправлял всем желающим с небольшой инструкцией. «Печатайте на принтере с двух сторон листа — сначала напечатайте нечетные листы, затем переверните листы на принтере и распечатайте четные.» Результат работы скрипта на обложке этой статьи.

Собственно говоря это всё — пользуйтесь для изучения языка или для изучения Apps Script.
Всем удачи.

P.S. Если кто знает аналогичные решения, пожалуйста, напиши в комментариях.

Only registered users can participate in poll. Log in, please.
Почему Вам интересна статья?
0% Хочу делать карточки.0
100% Хочу посмотреть техническое решение.2
0% Шел мимо — задержался :)0
2 users voted. Nobody abstained.
Tags:
Hubs:
Total votes 5: ↑5 and ↓0+5
Comments14

Articles