2 changed files with 80 additions and 0 deletions
@ -0,0 +1,8 @@ |
|||||||
|
#!/bin/sh |
||||||
|
in_file=$1 |
||||||
|
out_wav_file_name="$1.wav" |
||||||
|
out_mp3_file_name="$1.mp3" |
||||||
|
cat "$1" | sed 's/[^a-zA-ZА-Яа-я0-9., ]//g' | text2wave -o "$out_wav_file_name" |
||||||
|
lame "$out_wav_file_name" "$out_mp3_file_name" |
||||||
|
rm "$out_wav_file_name" |
||||||
|
|
@ -0,0 +1,72 @@ |
|||||||
|
#!/bin/bash |
||||||
|
# Озвучивание русского текста из файла |
||||||
|
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 ]; 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&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 |
||||||
|
|
Loading…
Reference in new issue