前提・実現したいこと
音声認識をして事前に設定された単語が認識されたらudp通信を利用してprintしたいです。
実行するとエラーなどは出ないのですが音声を認識してくれません。
何か問題点があれば指摘してもらえると助かります。
該当のソースコード
python
1# -*- encoding: UTF-8 -*- 2 3import speech_recognition as sr 4import subprocess 5import tempfile 6from socket import * 7import random 8 9a_list = ["1", "2", "3", "4"] 10 11class udpsend(): 12 def __init__(self): 13 14 SrcIP = "127.0.0.1" 15 SrcPort = 11111 16 self.SrcAddr = (SrcIP,SrcPort) 17 18 DstIP = "127.0.0.1" 19 DstPort = 22222 20 self.DstAddr = (DstIP,DstPort) 21 22 self.udpClntSock = socket(AF_INET, SOCK_DGRAM) 23 self.udpClntSock.bind(self.SrcAddr) 24 25 def send(self, a_list): 26 27 data = a_list 28 data = data.encode('utf-8') 29 self.udpClntSock.sendto(data, self.DstAddr) 30 31while True: 32 r = sr.Recognizer() 33 with sr.Microphone() as source: 34 print("何か話してください") 35 audio = r.listen(source) 36 37 try: 38 text = r.recognize_google(audio, language = "ja-JP") 39 40 except sr.UnknownValueError: 41 print("認識不可") 42 43 except sr.RequestError as e: 44 print("要求不可" 45 "{0}".format(e)) 46 47 else: 48 print(text) 49 50 if text == "こんにちは": 51 udp = udpsend() # クラス呼び出し 52 udp.send(a_list[0]) # 関数実行 53 54 udp = 0 55 56 else: 57 udp = udpsend() 58 udp.send(random.choice(a_list)) 59 60 udp = 0 61 if text == "終わり": 62 break 63print("完了")
python
1# -*- coding: utf-8 -*- 2 3from socket import * 4import random 5 6ran_list = ["1", "2", "3", "4"] 7 8## UDP受信クラス 9class udprecv(): 10 def __init__(self): 11 12 SrcIP = "127.0.0.1" 13 SrcPort = 22222 14 self.SrcAddr = (SrcIP, SrcPort) 15 16 self.BUFSIZE = 2048 17 self.udpServSock = socket(AF_INET, SOCK_DGRAM) 18 self.udpServSock.bind(self.SrcAddr) 19 20 def recv(self): 21 while True: 22 23 data, addr = self.udpServSock.recvfrom(self.BUFSIZE) 24 25 if data == "1": 26 print("こんにちは") 27 28 else: 29 print("いいえ") 30 31udp = udprecv() 32udp.recv() 33
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。