Skip to main content

A simple package for interfacing with Dialogflow

Project description

Affability

Affability allows for an easy utilization of Google's DialogFlow for natural language understanding. It allows for calling a single function and returning the result from Dialogflow as a class containing all the pertinent data such as detected intent. Communicating with Dialogflow through Affability trades-off features and customizability for simplicity and conciseness.

This can be utilized to understand commands and then perform the relevant tasks based from the detected intent. Affability is ultimately designed to have the ability to assist with a quadruped robot project in the future.

Dependencies

Installing using the requirements.txt file:

pip install -r requirements.txt

Installing manually:

pip install SpeechRecognition
pip install dialogflow

Installation

pip install Affability

Usage

The module can be imported as Affability:

import Affability

Using the understand function:

The understand function contains 5 parameters: text, credentials, projectID, languageCode, and sessionID. Text is text to be analyzed, credentials is the file path of the authentication key, projectID is the project ID, languageCode is the language, and sessionID is the session ID. All parameters are strings.

Affability.understand('textToBeAnalyzed', 'filepath', 'projectIDname', 'en-US', 'me')

The understand function returns the results as an organizer class. This class contains detectedIntent, confidence, reply, action, requiredParamsPresent, and replyParams.

class organizer:
    def __init__(self, detectedIntent, confidence, reply, action, requiredParamsPresent, replyParams):
        self.detectedIntent = detectedIntent
        self.confidence = confidence
        self.reply = reply
        self.action = action
        self.requiredParamsPresent = requiredParamsPresent
        self.replyParams = replyParams

For example, to extract and print detected intent:

reply = Affability.understand('textToBeAnalyzed', 'filepath', 'projectIDname', 'en-US', 'me')
print(reply.detectedIntent)

Sample usage

The example_usage.py file demonstrates the ease of communicating with Dialogflow through Affability.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

affability-1.0.1.tar.gz (2.1 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

affability-1.0.1-py3-none-any.whl (2.9 kB view details)

Uploaded Python 3

File details

Details for the file affability-1.0.1.tar.gz.

File metadata

  • Download URL: affability-1.0.1.tar.gz
  • Upload date:
  • Size: 2.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.2.0 pkginfo/1.5.0.1 requests/2.22.0 setuptools/49.2.0 requests-toolbelt/0.9.1 tqdm/4.32.1 CPython/3.7.3

File hashes

Hashes for affability-1.0.1.tar.gz
Algorithm Hash digest
SHA256 fcdce7764cefdded859cf46face5e1866b47000da1f4bda4117f2081a44c422a
MD5 d107470d53485feb6feffcd028b26b90
BLAKE2b-256 6575b2985f5dfdf5454cc6e182657bbeeca3b5377f84ff83632877a38010adaa

See more details on using hashes here.

File details

Details for the file affability-1.0.1-py3-none-any.whl.

File metadata

  • Download URL: affability-1.0.1-py3-none-any.whl
  • Upload date:
  • Size: 2.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.2.0 pkginfo/1.5.0.1 requests/2.22.0 setuptools/49.2.0 requests-toolbelt/0.9.1 tqdm/4.32.1 CPython/3.7.3

File hashes

Hashes for affability-1.0.1-py3-none-any.whl
Algorithm Hash digest
SHA256 e2df7a80637fb8f087533311dffdf85768776a11ebcd2687c15c135a63664c0b
MD5 babcb68fa86b6ddcc5ad7c46da6bb43c
BLAKE2b-256 bdd25bd70c925c470e8b04fcc02aeed75a7864acab507e84bacfc0a0915bd185

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page