Удалить кавычки из String в Python
У меня есть код python, который распознает речь с помощью механизма Google STT и вернет мне результаты, но я получаю результаты в строках с "кавычками". Мне не нужны эти кавычки в моем коде, поскольку я буду использовать его для запуска многих команд, и это не сработает. Я ничего не пробовал, пока не пытался ничего попробовать! Это функция в коде python, которая распознает речь:
def recog():
p = subprocess.Popen(['./speech-recog.sh'], stdout=subprocess.PIPE,
stderr=subprocess.PIPE)
global out,err
out, err = p.communicate()
print out
Это speech-recog.sh:
#!/bin/bash
hardware="plughw:1,0"
duration="3"
lang="en"
hw_bool=0
dur_bool=0
lang_bool=0
for var in "[email protected]"
do
if [ "$var" == "-D" ] ; then
hw_bool=1
elif [ "$var" == "-d" ] ; then
dur_bool=1
elif [ "$var" == "-l" ] ; then
lang_bool=1
elif [ $hw_bool == 1 ] ; then
hw_bool=0
hardware="$var"
elif [ $dur_bool == 1 ] ; then
dur_bool=0
duration="$var"
elif [ $lang_bool == 1 ] ; then
lang_bool=0
lang="$var"
else
echo "Invalid option, valid options are -D for hardware and -d for duration"
fi
done
arecord -D $hardware -f S16_LE -t wav -d $duration -r 16000 | flac - -f --best --sample-rate 16000 -o /dev/shm/out.flac 1>/dev/shm/voice.log 2>/dev/shm/voice.log; curl -X POST --data-binary @/dev/shm/out.flac --user-agent 'Mozilla/5.0' --header 'Content-Type: audio/x-flac; rate=16000;' "https://www.google.com/speech-api/v2/recognize?output=json&lang=$lang&key=key&client=Mozilla/5.0" | sed -e 's/[{}]/''/g' | awk -F":" '{print $4}' | awk -F"," '{print $1}' | tr -d '\n'
rm /dev/shm/out.flac
Это было взято из программы Стивена Хиксона Voicecommand, сделанной для малины Pi
Ответы
Ответ 1
Просто используйте строковые методы .replace()
если они встречаются повсеместно, или .strip()
если они встречаются только в начале и/или в конце:
a = '"sajdkasjdsak" "asdasdasds"'
a = a.replace('"', '')
'sajdkasjdsak asdasdasds'
# or, if they only occur at start and end...
a = a.strip('\"')
'sajdkasjdsak" "asdasdasds'
# or, if they only occur at start...
a = a.lstrip('\"')
# or, if they only occur at end...
a = a.rstrip('\"')
Ответ 2
Вы можете заменить символы "quote" пустой строкой, например:
>>> a = '"sajdkasjdsak" "asdasdasds"'
>>> a
'"sajdkasjdsak" "asdasdasds"'
>>> a = a.replace('"', '')
>>> a
'sajdkasjdsak asdasdasds'
В вашем случае вы можете сделать то же самое для переменной out
.
Ответ 3
Это можно сделать несколькими способами.
-
Вы можете использовать встроенную .replace()
функцию .replace()
чтобы заменить все вхождения кавычек в заданной строке:
>>> s = '"abcd" efgh'
>>> s.replace('"', '')
'abcd efgh'
>>>
-
Вы можете использовать строчную функцию .join()
и выражение генератора, чтобы удалить все кавычки из заданной строки:
>>> s = '"abcd" efgh'
>>> ''.join(c for c in s if c not in '"')
'abcd efgh'
>>>
-
Вы можете использовать регулярное выражение, чтобы удалить все кавычки из заданной строки. Это дает дополнительное преимущество, позволяя вам контролировать, когда и где цитата должна быть удалена:
>>> s = '"abcd" efgh'
>>> import re
>>> re.sub('"', '', s)
'abcd efgh'
>>>
Ответ 4
Вы можете использовать eval() для этой цели
>>> url = "'http address'"
>>> eval(url)
'http address'
в то время как eval() создает риск, я думаю, что в этом контексте это безопасно.
Ответ 5
if string.startswith('"'):
string = string[1:]
if string.endswith('"'):
string = string[:-1]