質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

ただいまの
回答率

90.76%

  • Python

    6867questions

    Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

  • Python 3.x

    5321questions

    Python 3はPythonプログラミング言語の最新バージョンであり、2008年12月3日にリリースされました。

昨日まで動作していたのにKeyErrorがで始めた

受付中

回答 1

投稿

  • 評価
  • クリップ 0
  • VIEW 155

jajauma007

score 4

音声認識APIを使ってプログラムを書いていました。
昨日までは正常に動作していたコードなのですが、突然KeyErrorでうまく認識結果を表示してくれなくなりました。

予想はresultsが空の状態で帰ってきているせいで不具合が起きていると思うのですが、解決策も思いつきません。

##### coding:utf8
import base64
from googleapiclient import discovery
import httplib2

import pyaudio  #録音機能を使うためのライブラリ
import wave     #wavファイルを扱うためのライブラリ
import time
import math
import audioop

#APIキーを設定
key = "APIキー"

DISCOVERY_URL = ('https://{api}.googleapis.com/$discovery/rest?'
                 'version={apiVersion}')

#音声を保存するファイル名
WAVE_OUTPUT_FILENAME = "sample10.wav"

RATE = 44100
CHUNK = 1024
CHANNELS = 1
FORMAT = pyaudio.paInt16
DECIBEL_THRESHOLD=50
frames=[]
frame_counter = 0
start_Rec = False

def get_speech_service():
    http = httplib2.Http()
    return discovery.build(
        'speech', 'v1', http=http, discoveryServiceUrl=DISCOVERY_URL, developerKey=key)

def SpeechAPI():
    #音声ファイルを開く
    waveFile = wave.open(WAVE_OUTPUT_FILENAME, 'wb')
    waveFile.setnchannels(CHANNELS)
    waveFile.setsampwidth(p.get_sample_size(FORMAT))
    waveFile.setframerate(RATE)
    waveFile.writeframes(b''.join(frames))
    waveFile.close()
    with open(WAVE_OUTPUT_FILENAME, 'rb') as speech:
        speech_content = base64.b64encode(speech.read()) 

    #APIの情報を取得して、音声認識を行う
    service = get_speech_service()
    service_request = service.speech().recognize(
        body={
            'config': {
                'encoding': 'LINEAR16',
                'sampleRateHertz': 44100,
                'languageCode': 'ja-JP', #日本語に設定
                'enableWordTimeOffsets': 'false',
            },
            'audio': {
                'content': speech_content.decode('UTF-8')
                }
            })

    #SpeechAPIによる認識結果を保存
    response = service_request.execute()

    #見やすいようにコンソール画面で出力
    for i in response["results"]:
        print(i["alternatives"][0]["transcript"],"confidence:" , i["alternatives"][0]["confidence"])

if __name__=='__main__':
    p = pyaudio.PyAudio()

    stream = p.open(format=FORMAT,
            channels=CHANNELS,
            rate=RATE, 
            input=True,
            frames_per_buffer=CHUNK)
    while True:
        data=stream.read(CHUNK)#ストリームを開く
        rms=audioop.rms(data,2)
        decibel=20*math.log10(rms)
        if decibel >= DECIBEL_THRESHOLD:#音圧レベルが50dB以上なら録音開始
            start_Rec=True
            frame_counter=0
        if start_Rec==True and decibel<DECIBEL_THRESHOLD:
            frame_counter+=1
            if frame_counter>=20:#録音開始後、20チャンク分の無音が続いた場合は録音終了
                frame_counter=0
                start_Rec=False
                stream.stop_stream()
                stream.close()#ストリーム閉じる
                p.terminate()
                SpeechAPI()#音声認識
                stream = p.open(format=FORMAT,#ストリーム再開
                                channels=CHANNELS,
                                rate=RATE, 
                                input=True,
                                frames_per_buffer=CHUNK)
                frames=[]
        if start_Rec==True:
            frames.append(data)
KeyError                                  Traceback (most recent call last)
<ipython-input-7-e368a73a5a1c> in <module>()
     89                 stream.close() #ストリーム閉じる
     90                 p.terminate()
---> 91                 SpeechAPI() #音声認識
     92                 stream = p.open(format=FORMAT,#ストリーム再開
     93                                 channels=CHANNELS,

<ipython-input-7-e368a73a5a1c> in SpeechAPI()
     63 
     64     #見やすいようにコンソール画面で出力
---> 65     for i in response["results"]:
     66         print(i["alternatives"][0]["transcript"],"confidence:" , i["alternatives"][0]["confidence"])
     67 

KeyError: 'results'
  • 気になる質問をクリップする

    クリップした質問は、後からいつでもマイページで確認できます。

    またクリップした質問に回答があった際、通知やメールを受け取ることができます。

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

回答 1

+1

とりあえず、responseをprintするコードを入れて見てみたらどうですか。


利用制限に引っかかっただけ、というのはありえませんか?
無料で使うと一日50回、とか出てきますが・・・

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2018/05/31 23:07

    GoogleのAPIは従量課金制なので制限とかはリファレンスを眺めても見当たらなかったです。

    response表示した結果、コンソールに空の辞書が表示されたのでやはり辞書が空のせいでfor文がうまく回っていないのだと思います。

    キャンセル

  • 2018/06/01 04:50

    そうですか。いずれにせよ、API側で問題が起きているっぽいので、その線でいろいろあたってみるしかなさそうです

    キャンセル

15分調べてもわからないことは、teratailで質問しよう!

  • ただいまの回答率 90.76%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

関連した質問

  • 解決済

    Watsonの音声認識

    IBM Watson のSpeech to text の使い方がまるでわからないのですが・・ どなたか教えてくださいませんか?? iOSで音声認識を試してみたいのです。

  • 受付中

    字下げについて

    お世話になります 本日マイナビ第26章を勉強しております http://news.mynavi.jp/series/python/026/ この中でどうしてもコマンドの字下げ

  • 受付中

    Watson の speech to text を HTTP REST で呼び出す方法

    前提・実現したいこと 【IBM Watson音声認識のAPI呼び出し】 IBM Watson の HTTP REST API で speech to text の recogn

  • 解決済

    PythonのCGIのwavファイルの読み込みに関してです。

    python初心者(python3.5)です。CGIの勉強をしていましてwavファイルの読み込みの方法がどうしてもわかりません。どなたかpythonに詳しい方、ご教示をお願い

  • 解決済

    PythonでPCM形式のデータをWAV形式に変換したい

    WAVのヘッダーについて pythonで外部のサーバーからおとしたPCMデータをwavに変換して再生したいのですが, WAVに変換するためのヘッダーの書き方がわかりません。 詳しい

  • 受付中

    動画から連番で画像を保存するプログラム

    前提・実現したいこと 動画(wmvファイル)を読み込んで、静止画(jpgファイル)を連番で保存したいです。 発生している問題・エラーメッセージ 画像が出力されない 該当のソ

  • 解決済

    音楽ファイルの再生時間やジャケットを取得したい

    プログラミング初学者です 現在mp3プレーヤーを作成しているのですが、ファイルの再生時間やジャケットを取得する方法にはどのような方法があるでしょうか ファイルの名前の取得にはmut

  • 解決済

    pygameを用いたMIDIの制御

    実現したい内容 pygameを用いてMIDIデバイスの入力を受け取り、リアルタイムでSin波で演奏 複数音の出力および、ベロシティの対応  発生してる問題 キーを押した時と離し

同じタグがついた質問を見る

  • Python

    6867questions

    Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

  • Python 3.x

    5321questions

    Python 3はPythonプログラミング言語の最新バージョンであり、2008年12月3日にリリースされました。