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