はい、皆さんこんにちは。私はシステム会社の営業部員をしております。最近では企業へのサイバー攻撃やウィルスメール等でセキュリティがどんどん上がっていき、良い意味では何もしなくとも自分のPCが侵食される心配はありません。自社でもVPN(バーチャル・プライベートネットワーク)を採用しており自社サイト等は完全に守られているに違いありません。ただし、ネットワークを強固にするために逆に困っている事もあります。それは無線でのネットワーク通信の遅さです。
1.作成のきっかけ
先輩から「社内の○○さんの携帯電話番号知らない。自社サイト5分探したけど見つからないし繋ぐと重いし遅いし時間の無駄なんだよね。」と言われ、その時は一緒になって探して確かこの場所にと目星がついている箇所を確認し、なんとか探し出せました。電話帳一覧がExcelになっていました。そこで、ピンときた私が思いついたのはVUI(Voice User Interface)機能を持ったVoice flowを使った携帯番号検索を開発する事でした。
2.まずはVoice flowの完成動画
— imupion (@5cyyzToVdzLw0x4) June 18, 2022
3.使用ツール
・Voice flow
・Googleスプレッドシート
4.作成手順
①最初にGoogleスプレッドシートに呼び出したい資料をコピーしておきます。
(今回はExcelで管理されていたファイルだったのですが、個人情報の記入があるためダミーを使用しました。)
②Voice flowにサインアップして(Googleアカウントを使うとスプレッドシートと連携しやすい)
Create Projectを押し、ChannelにAmazon Alexaを今回採用。Invocation Nameには題名を入力し、LocalesにはJapanese(JP)つまり日本語を採用し、Createボタンを押して始める。
参考
インフォメーション
Voice flowの無料版は2つまでしか作成を保持出来ません。
③左にあるツールバーからResponseの中のSpeakをdrag&dropし、StartのBlockとLineで繋ぐ。SpeakBlockを開き話させたい文言を入力。
④turn2で部署名の質問文を投じた後はツールバーのUser Inputから今回はChoiceを選択しdrag&drop。分岐を作ります。
ここで初めて掛け合いが出来ます。部署名がなかったり違う事を発声した場合に戻って来れるようにリターンするリクエストも用意しておきます。
余談
この後作成中に分岐が増えすぎるのと要の番号検索に辿り着くまでに時間が掛かりそうだったので、部署名だけは敢えてセキュリティとして入れておきました。結果OKの場合、次に繋がるところは全部同じにしました。もう一つ理由としては他部署に異動しても携帯は同じだったりするのでこの流れにしました。
turn3の中で選択する文言を判定させるため、キーワードに近い文言を学習させます。
⑤turn4で本題の人物検索に入ります。再度ツールバーのUser Inputから選択するのですが、今回はCaptureを選択しdrag&drop。その後のBlockに組み合わせを意味するintegrationからGoogle Sheetsを選択しdrag&drop。
⑥turn5では下図のように入力。{name}はGoogleスプレッドシートから名前を呼び出すために必須。
⑦turn6のGoogle SheetsではRetrieve Dataで自分のGoogleアカウントを呼び出してSpreadsheetに先ほど作成したGoogleスプレッドシートを選択し必要なSheetを選択する。
その後With Settingsには取り込む列nameとturn5で入力した変数{name}を入力。
さらにMapping Outputでは呼び出す列のnumberとその値となるnumber(変数ではない)を入力。テストデータも確認しておく。
⑧turn7にSpeakを置き下図の通りSSML(音声マークアップ言語)を使用しました。
⑨後は最後まで話が通じるようにChoiceとSpeakを繋げたり同様のBlockはコピーしました。
完成したフロー図です。
5.苦労した点
その1
turn7に入れる文言をAlexaが話す際、最初は電話番号で話さず数字として認識され「じゅうまん・・・」と返された時は「そうなるのか」と悩みました。過去にも同じような事やられていないか調べたら類似案件がありそれを引用させていただきました。
その2
「メモの準備をお願いします。」を話した後にすぐに番号を続けて話すのでメモが取りづらいと感じたので間合いが出る言語を探し1秒間開ける事を見つけて入れましたが、逆に話さなくなってしまいましたのでそれは断念し、違う文言を入れる事にしました。たった今、文言に「電話番号」を追加変更しました。その方が会話が成り立ちます。
6.確認終えて反省
改良の余地を残しましたが、テストもテキスト入力だったので少し寂しく思いました。Alexaも安価で手に入れられるのであれば本番実装したいです。テスト実装は出来たのでダミーを本番に変更し、先輩にも使ってもらいフィードバックをもらえたら良かったと反省です。ここまで読んでいただきありがとうございます。もしよければ前回記事も見ていただけると幸いです。