AlexaのスキルでWeb上から取得したテキストを喋らせよう
Amazonの音声アシスタント「Alexa」では、ブラウザ上で手軽に「スキル」を作成して機能を追加できるが、あらかじめ用意した内容を喋るだけだと出来ることは限られてしまう。ネット上のデータを元に毎回違う内容を喋ったり、聞かせた内容を送信するなど、ネットサービスを活用したスキルも作ってみたいところだ。
Amazonのサーバ上で実行される「Alexa-hostedスキル」でもHTTPやHTTPSによる通信は可能だが、処理完了を待たずに次の処理に進む非同期方式のため、取得した内容から応答内容を生成してAlexaに返すには少々ややこしい記述が必要だ。また、HTTP/HTTPSモジュールのバージョンが古く、新しいバージョンで追加された簡潔な書式でのパラメータ指定ができないことにも混乱させられる。
ここに現時点のAlexa-hostedスキルで動作するHTTP通信処理の例を用意したので、Web上のデータを利用したAlexaスキルを作りたい人は参考にして欲しい。
Alexaがホストするカスタムスキルを作成したら、「コードエディタ」画面の内容に下記ファイルからコピーした内容を上書きしよう。「ビルド」画面での設定は特に不要だ。
冒頭の「httpget」関数は、HTTPやHTTPSによるデータ取得を使いやすくするためのものだ。
今回の例では、単にURLで示されたWebページを取得する形でしか使っていないが、第2引数に文字列を指定して「POST」メソッドで送信できる他、第3引数にリクエストヘッダの名前:値ペアを列挙したオブジェクトを指定することもできる。
httpget関数内で使われている「HTTP」「HTTPS」モジュールの詳しい仕様は以下のページに掲載されている。Alexa-hostedスキルで利用できるバージョンが古めなので、新しいバージョンで追加された機能は使えないことに注意が必要だ。
・HTTP | Node.js v6.17.1 Documentation
「LaunchRequestHandler」以下が、httpget関数を利用した処理を記述した部分だ。
今回の例では、あんスマのトップページを取得した後、最初のピックアップ記事のURLを抜き出し、取得した記事ページからタイトルと本文を抜き出し、HTMLタグを除去して読み上げテキストを生成し、応答オブジェクトにセットして返すという処理になっているぞ。
好きなサイトの最新記事を読み上げるようにカスタマイズしたければ、最初の「httpget(‘~’)」内のURLと、2つの「match(~)」内の正規表現パターンを書き換えよう。正規表現の使い方は、下記ページなどで解説されているぞ。
httpget関数の返り値は、処理の完了後に結果を受け取れるようにする「Promise」というオブジェクトになっている。
Promiseオブジェクトの「then」メソッドに結果の値を受け取って加工して返す関数を与えれば、加工された値を結果とする新たなPromiseオブジェクトが返される。代わりにhttpget関数などの返り値のPromiseオブジェクトを返せば、さらにその処理の結果を待ってから最終的な結果とするPromiseオブジェクトになる。
Alexaのリクエストハンドラ関数では、「responseBuilder…getResponse()」で取得できる応答オブジェクトの代わりに、thenメソッドに与えた関数内で応答オブジェクトを返すPromiseオブジェクトを返せば、完了を待ってから結果に応じてAlexaを動作させてくれる。
Promiseの仕組みについては非常にややこしいので、詳しく知りたい人は下記のページなどを参照して欲しい。
・Promiseを使う – JavaScript | MDN
プログラム例を改造して好きなサイトの読み上げスキルを作成したら「テスト」ページで「非公開」をクリックして「開発中」に変更してテスト可能状態にしよう。
この画面の入力欄に「○○のスキルを開いて」のように入力すれば、手軽に動作確認できるぞ。
上手く抜き出したテキストを読み上げられたら、実際にAlexa搭載機器やアプリに呼びかけて利用しよう。
関連記事
Alexaの自作スキルでお気に入りのサイトをフラッシュニュースに対応させよう
Alexaのスキルを自作して手持ちの音楽ファイルを再生させよう
実質有料化のIFTTT代替!自作Alexaスキルでスマートホーム機器を自在に活用しよう
Alexaの「スキル」で「フラッシュニュース」の内容を自分好みにカスタマイズ
「Alexaスキル」でFireタブレットの音声アシスタントに機能を追加
Amazon開発者アカウントを作成してAlexaスキルを自作しよう
Alexaやスマートホーム機器をパソコンなどと連携させるためのスマートホームスキルを作成しよう
Wikipediaを読み上げるAlexaスキル「ウィキサーチ」
画面付きのAlexaでお気に入りの動画を再生するスキルを自作しよう
2019年06月04日17時04分 公開 | カテゴリー: 便利化・快適化 | キーワード:おすすめ, チップス | Short URL
ツイート
最新記事
- MacBookやiPad用のクラムシェルスタンド!もちろんWindowsパソコンでも!
- ベッドに寄りかかるときに使ってほしい三角クッション!ポケット付きでスマホを入れておける!
- 超軽量な背もたれクッション!持ち運んで家中どこでもくつろげる!
- 高反発な三角クッション!ソファやベッドで背もたれとして使える!
- 幅広のフットレストで快適にパソコン作業を!無段階に調節できるチルトフットレスト!
- シリコン編組ケーブルでながーく使える!タブレットやパソコンの充電に!
- 縦型ノートパソコンスタンドでスマートにパソコンを置いておける!スロット幅は簡単に調整できる!
- 家庭やオフィスに最適な木製の足踏み台!血流を良くしてリフレッシュにも!
- 足ふみ運動でリフレッシュ!パソコン作業にも最適な動くフットレスト!
- 足裏マッサージでリフレッシュ!デスク下を快適に過ごせるフットレスト!
- デスクワークの姿勢を改善!足を置くためのフットレスト!
- 気分に合わせて選べるアタッチメントホルダー!ストラップやネックストラップをスマホに手軽に取り付け!
- カラバリ豊富なスマホベルト!スマホ背面に貼り付けるだけ!
- 簡単取り付け簡単利用!高い粘着性能で安心して使えるスマホリング!
- スマホの充電もできるヘッドフォンスタンド!ケーブルホルダー付きで整理整頓できる!
- スマホサイズで携帯便利な自撮り棒!わずか140gの超軽量設計!
- ゲームを楽しむだけで無く、おしゃれにも使えるカラバリ!有線でも無線でも使えるゲームコントローラー!
- 小さく運ぶ、大きく使う!移動中も効率的に休める枕!
- 柔軟なケーブル管理!すべてのケーブルが絡まないようにする結束バンド!
- 一瞬でくるっとまとまる充電ケーブル!急速充電も高速データ伝送も対応!
- 小型化とスタイルの融合!テンキーレスで一日ゲームをするのも快適!
- 太めのケーブルも使えるマグネット式ケーブルクリップ!6個セットで家中どこでも使える!
- クランプで手軽に設置できるケーブルトレー!使い方によって小物入れとして使うことも!
- 配線を整理してスッキリ!デスク裏に設置する布製ケーブルトレー!
- 液晶ディスプレイの上を小物置きに!設置も取り外しも簡単なディスプレイボード!
- 照明の常識が変わる究極のモニターライト!自動調光で常に最適な明るさ!
- 狭いデスクを広々使う!可動域の広いモニターアーム!
- 大きな文字で見やすいデジタル時計!壁掛け時計としても置き時計としても!
- 3in1のヘッドホンスタンド!USBハブや 3.5mmオーディオ機能も!
- ゲームやテレワークを快適に!目に優しい設計のモニターライト!