#!/bin/bash # Озвучивание русского текста из файла # Параметры emotion='neutral' #'Default is neutral. Also supported are good (friendly) and evil (angry)' speaker='ermil' # (Optional): Speaker voice. Default is zahar. Supported female voices are jane, oksana, alyss, omazh and male voices are zahar and ermil. #["oksana","jane","omazh","zahar","ermil","silaerkan","erkanyavas","alyss", "nick","alena","filipp"] speed='1.0' input_file_name="$1" source_text=$(cat "${input_file_name}") #{ # GUI # Удаляем все пробелы в начале и в конце строк и заменяем два и более пробелов на один source_text="$(echo -n "$source_text" | sed 's/^ *//;s/[ ^]*$//;s/ */ /g')" #echo "Исходный текст $source_text" ping -c 3 ya.ru &>/dev/null || { echo "Интернет недоступен."; exit; } audio_file_names_array=() split_size=1450 echo "Длина текста ${#source_text}: Разбиваем на части по $split_size" space_char=" " file_index=0 for ((i=1;i<=${#source_text};i++)); do cur_char=${source_text:$i-1:1} cur_text="${cur_text}${cur_char}" if [ "$cur_char" = "$space_char" ] && [ ${#cur_text} -ge $split_size ] || [ $i = ${#source_text} ]; then let file_index+=1 echo "Часть номер $file_index" echo "------------------------------" echo $cur_text echo "------------------------------" # Максимальная длина SEND_IRI - 1590 символов, длина SEND_IRI без текста = 75 символов # Максимальная длина текста = 1590 - 75 = 1515 символов text_count=$(echo "$cur_text" | wc -m) [ $text_count -ge 1515 ] && { echo "Превышено максимальное колличество символов - 1515"; exit; } audio_file_name="${input_file_name}_${file_index}.mp3" echo -en "\nЗагрузка аудио в файл '$audio_file_name'...\n" #touch "$audio_file_name" wget -q -O "$audio_file_name" "http://tts.voicetech.yandex.net/tts?format=mp3&quality=hi&lang=ru_RU&speed=$speed&speaker=$speaker&emotion=$emotion&text=${cur_text}" || { echo "Ошибка при загрузке аудио."; exit; } echo "Файл '$audio_file_name' загружен." IFS="" audio_file_names_array+=($audio_file_name) cur_text="" fi done cmd="" for ((i = 0; i < ${#audio_file_names_array[@]}; i++)) do cmd="$cmd|${audio_file_names_array[$i]}" done cmd=${cmd:1} out_file="${input_file_name}_yatts.mp3" echo "Объединяем файлы $cmd в $out_file" ffmpeg -i "concat:$cmd" -acodec copy "$out_file" IFS="" for ((i = 0; i < ${#audio_file_names_array[@]}; i++)) do f="${audio_file_names_array[$i]}" echo "Удаляем файл '$f'" rm "$f" done echo "Конечный файл создан '$out_file'!" #} | zenity --source_text-info --width=550 --height=450 --title="Озвучивание текста при помощи YaTTS" # GUI