當前位置: 首頁>>代碼示例>>Python>>正文


Python rasa_sdk.Tracker方法代碼示例

本文整理匯總了Python中rasa_sdk.Tracker方法的典型用法代碼示例。如果您正苦於以下問題:Python rasa_sdk.Tracker方法的具體用法?Python rasa_sdk.Tracker怎麽用?Python rasa_sdk.Tracker使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在rasa_sdk的用法示例。


在下文中一共展示了rasa_sdk.Tracker方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。

示例1: submit

# 需要導入模塊: import rasa_sdk [as 別名]
# 或者: from rasa_sdk import Tracker [as 別名]
def submit(
        self,
        dispatcher: CollectingDispatcher,
        tracker: Tracker,
        domain: Dict[Text, Any],
    ) -> List[Dict]:
        """Define what the form has to do
            after all required slots are filled"""

        # decide if the rating is low and send according finish message
        rating = int(tracker.get_slot("rating"))

        if rating < 3:
            dispatcher.utter_template("utter_influence_done", tracker)
        else:
            dispatcher.utter_template("utter_awesome", tracker)
            
        return [] 
開發者ID:cedextech,項目名稱:rasa-chatbot-templates,代碼行數:20,代碼來源:actions.py

示例2: run

# 需要導入模塊: import rasa_sdk [as 別名]
# 或者: from rasa_sdk import Tracker [as 別名]
def run(
        self,
        dispatcher,  # type: CollectingDispatcher
        tracker,  # type: Tracker
        domain,  # type:  Dict[Text, Any]
    ):  # type: (...) -> List[Dict[Text, Any]]

        url = f"https://rasa.com/carbon/index.html?" \
              f"&rasaxhost=https://carbon.rasa.com" \
              f"&conversationId={tracker.sender_id}" \
              f"&destination=https://offset.earth%2F%3Fr%3D5de3ac5d7e813f00184649ea"

        link_1_url = url + f"&label=link-1-clicked"
        link_2_url = url + f"&label=link-2-clicked"

        return [SlotSet("link_1_url", link_1_url), SlotSet("link_2_url", link_2_url)] 
開發者ID:RasaHQ,項目名稱:carbon-bot,代碼行數:18,代碼來源:actions.py

示例3: resolve_mention

# 需要導入模塊: import rasa_sdk [as 別名]
# 或者: from rasa_sdk import Tracker [as 別名]
def resolve_mention(tracker: Tracker) -> Text:
    """
    Resolves a mention of an entity, such as first, to the actual entity.
    If multiple entities are listed during the conversation, the entities
    are stored in the slot 'listed_items' as a list. We resolve the mention,
    such as first, to the list index and retrieve the actual entity.

    :param tracker: tracker
    :return: name of the actually entity
    """
    graph_database = GraphDatabase()

    mention = tracker.get_slot("mention")
    listed_items = tracker.get_slot("listed_items")

    if mention is not None and listed_items is not None:
        idx = int(graph_database.map("mention-mapping", mention))

        if type(idx) is int and idx < len(listed_items):
            return listed_items[idx] 
開發者ID:RasaHQ,項目名稱:tutorial-knowledge-base,代碼行數:22,代碼來源:actions.py

示例4: submit

# 需要導入模塊: import rasa_sdk [as 別名]
# 或者: from rasa_sdk import Tracker [as 別名]
def submit(self, dispatcher, tracker, domain):
        # type: (CollectingDispatcher, Tracker, Dict[Text, Any]) -> List[Dict]
        """Define what the form has to do
           after all required slots are filled
           basically it generate sentiment analysis
           using the user's feedback"""

        sid = SentimentIntensityAnalyzer()

        all_slots = tracker.slots
        for slot, value in all_slots.copy().items():
            if slot in self.required_slots(tracker):
                res = sid.polarity_scores(value)
                score = res.pop('compound', None)
                classi, confidence = max(res.items(), key=lambda x: x[1])
                # classification of the feedback, could be pos, neg, or neu
                all_slots[slot+'_class'] = classi
                # sentiment score of the feedback, range form -1 to 1
                all_slots[slot+'_score'] = score

        return [SlotSet(slot, value) for slot, value in all_slots.items()] 
開發者ID:Cheukting,項目名稱:rasa_workshop,代碼行數:23,代碼來源:actions.py

示例5: run

# 需要導入模塊: import rasa_sdk [as 別名]
# 或者: from rasa_sdk import Tracker [as 別名]
def run(self, dispatcher, tracker, domain):
        # type: (CollectingDispatcher, Tracker, Dict[Text, Any]) -> List[Dict[Text, Any]]

        result = tracker.slots
        name = result['name']
        if name is None:
            name = 'Anonymous'
        else:
            name = name + "'s"
        http_result =""""""
        for key, value in result.items():
            if key != 'requested_slot':
                http_result += """<p>{}: {}</p>""".format(key, value)

        # url of the server set up by result.py
        url = 'http://localhost:8080/?name={}&result={}'.format(name, http_result)
        webbrowser.open(url)

        return [] 
開發者ID:Cheukting,項目名稱:rasa_workshop,代碼行數:21,代碼來源:actions.py

示例6: request_next_slot

# 需要導入模塊: import rasa_sdk [as 別名]
# 或者: from rasa_sdk import Tracker [as 別名]
def request_next_slot(
        self,
        dispatcher: "CollectingDispatcher",
        tracker: "Tracker",
        domain: Dict[Text, Any],
    ) -> Optional[List[EventType]]:
        """Request the next slot and utter template if needed,
            else return None"""

        for slot in self.required_slots(tracker):
            if self._should_request_slot(tracker, slot):
                logger.debug(f"Request next slot '{slot}'")
                dispatcher.utter_message(template=f"utter_ask_{slot}", **tracker.slots)
                return [SlotSet(REQUESTED_SLOT, slot)]

        # no more required slots to fill
        return None 
開發者ID:RasaHQ,項目名稱:rasa-sdk,代碼行數:19,代碼來源:forms.py

示例7: _validate_if_required

# 需要導入模塊: import rasa_sdk [as 別名]
# 或者: from rasa_sdk import Tracker [as 別名]
def _validate_if_required(
        self,
        dispatcher: "CollectingDispatcher",
        tracker: "Tracker",
        domain: Dict[Text, Any],
    ) -> List[EventType]:
        """Return a list of events from `self.validate(...)`
            if validation is required:
            - the form is active
            - the form is called after `action_listen`
            - form validation was not cancelled
        """
        if tracker.latest_action_name == "action_listen" and tracker.active_form.get(
            "validate", True
        ):
            logger.debug(f"Validating user input '{tracker.latest_message}'")
            if utils.is_coroutine_action(self.validate):
                return await self.validate(dispatcher, tracker, domain)
            else:
                return self.validate(dispatcher, tracker, domain)
        else:
            logger.debug("Skipping validation")
            return [] 
開發者ID:RasaHQ,項目名稱:rasa-sdk,代碼行數:25,代碼來源:forms.py

示例8: test_get_attribute_slots

# 需要導入模塊: import rasa_sdk [as 別名]
# 或者: from rasa_sdk import Tracker [as 別名]
def test_get_attribute_slots():
    object_attributes = ["name", "cuisine", "price-range"]

    expected_attribute_slots = [
        {"name": "name", "value": "PastaBar"},
        {"name": "cuisine", "value": "Italian"},
    ]

    tracker = Tracker(
        "default",
        {"name": "PastaBar", "cuisine": "Italian"},
        {},
        [],
        False,
        None,
        {},
        "action_listen",
    )

    attribute_slots = get_attribute_slots(tracker, object_attributes)

    for a in attribute_slots:
        assert a in expected_attribute_slots 
開發者ID:RasaHQ,項目名稱:rasa-sdk,代碼行數:25,代碼來源:test_utils.py

示例9: test_extract_requested_slot_default

# 需要導入模塊: import rasa_sdk [as 別名]
# 或者: from rasa_sdk import Tracker [as 別名]
def test_extract_requested_slot_default():
    """Test default extraction of a slot value from entity with the same name
    """
    form = FormAction()

    tracker = Tracker(
        "default",
        {"requested_slot": "some_slot"},
        {"entities": [{"entity": "some_slot", "value": "some_value"}]},
        [],
        False,
        None,
        {},
        "action_listen",
    )

    slot_values = form.extract_requested_slot(CollectingDispatcher(), tracker, {})
    assert slot_values == {"some_slot": "some_value"} 
開發者ID:RasaHQ,項目名稱:rasa-sdk,代碼行數:20,代碼來源:test_forms.py

示例10: test_submit

# 需要導入模塊: import rasa_sdk [as 別名]
# 或者: from rasa_sdk import Tracker [as 別名]
def test_submit(form_class: Type[FormAction]):
    tracker = Tracker(
        "default",
        {"some_slot": "foobar", "other_slot": None},
        {"intent": "greet"},
        [],
        False,
        None,
        {"name": "some_form", "validate": False, "rejected": False},
        "action_listen",
    )

    form = form_class()
    events = await form.run(dispatcher=None, tracker=tracker, domain=None)

    assert events[0]["value"] == 42 
開發者ID:RasaHQ,項目名稱:rasa-sdk,代碼行數:18,代碼來源:test_forms.py

示例11: validate_cuisine

# 需要導入模塊: import rasa_sdk [as 別名]
# 或者: from rasa_sdk import Tracker [as 別名]
def validate_cuisine(
        self,
        value: Text,
        dispatcher: CollectingDispatcher,
        tracker: Tracker,
        domain: Dict[Text, Any],
    ) -> Dict[Text, Any]:
        """Validate cuisine value."""

        if value.lower() in self.cuisine_db():
            # validation succeeded, set the value of the "cuisine" slot to value
            return {"cuisine": value}
        else:
            dispatcher.utter_message(template="utter_wrong_cuisine")
            # validation failed, set this slot to None, meaning the
            # user will be asked for the slot again
            return {"cuisine": None} 
開發者ID:botfront,項目名稱:rasa-for-botfront,代碼行數:19,代碼來源:actions.py

示例12: validate_outdoor_seating

# 需要導入模塊: import rasa_sdk [as 別名]
# 或者: from rasa_sdk import Tracker [as 別名]
def validate_outdoor_seating(
        self,
        value: Text,
        dispatcher: CollectingDispatcher,
        tracker: Tracker,
        domain: Dict[Text, Any],
    ) -> Dict[Text, Any]:
        """Validate outdoor_seating value."""

        if isinstance(value, str):
            if "out" in value:
                # convert "out..." to True
                return {"outdoor_seating": True}
            elif "in" in value:
                # convert "in..." to False
                return {"outdoor_seating": False}
            else:
                dispatcher.utter_message(template="utter_wrong_outdoor_seating")
                # validation failed, set slot to None
                return {"outdoor_seating": None}

        else:
            # affirm/deny was picked up as T/F
            return {"outdoor_seating": value} 
開發者ID:botfront,項目名稱:rasa-for-botfront,代碼行數:26,代碼來源:actions.py

示例13: run

# 需要導入模塊: import rasa_sdk [as 別名]
# 或者: from rasa_sdk import Tracker [as 別名]
def run(
        self, dispatcher, tracker: Tracker, domain: Dict[Text, Any]
    ) -> List[Dict[Text, Any]]:

        conversation_id = tracker.sender_id

        dispatcher.utter_message(
            f"The ID of this conversation is: " f"{conversation_id}."
        )

        dispatcher.utter_message(
            f"Trigger an intent with "
            f'curl -H "Content-Type: application/json" '
            f'-X POST -d \'{{"name": "EXTERNAL_dry_plant", '
            f'"entities": {{"plant": "Orchid"}}}}\' '
            f"http://localhost:5005/conversations/{conversation_id}/"
            f"trigger_intent"
        )

        return [] 
開發者ID:botfront,項目名稱:rasa-for-botfront,代碼行數:22,代碼來源:actions.py

示例14: submit

# 需要導入模塊: import rasa_sdk [as 別名]
# 或者: from rasa_sdk import Tracker [as 別名]
def submit(
        self,
        dispatcher: CollectingDispatcher,
        tracker: Tracker,
        domain: Dict[Text, Any],
    ) -> List[EventType]:
        """Once we have an email, attempt to add it to the database"""

        email = tracker.get_slot("email")
        client = MailChimpAPI(config.mailchimp_api_key)
        # if the email is already subscribed, this returns False
        added_to_list = client.subscribe_user(config.mailchimp_list, email)

        # utter submit template
        if added_to_list:
            dispatcher.utter_message(template="utter_confirmationemail")
        else:
            dispatcher.utter_message(template="utter_already_subscribed")
        return [] 
開發者ID:RasaHQ,項目名稱:rasa-demo,代碼行數:21,代碼來源:actions.py

示例15: run

# 需要導入模塊: import rasa_sdk [as 別名]
# 或者: from rasa_sdk import Tracker [as 別名]
def run(
        self,
        dispatcher: CollectingDispatcher,
        tracker: Tracker,
        domain: Dict[Text, Any],
    ) -> List[EventType]:

        # Fallback caused by TwoStageFallbackPolicy
        if (
            len(tracker.events) >= 4
            and tracker.events[-4].get("name") == "action_default_ask_affirmation"
        ):

            dispatcher.utter_message(template="utter_restart_with_button")

            return [SlotSet("feedback_value", "negative"), ConversationPaused()]

        # Fallback caused by Core
        else:
            dispatcher.utter_message(template="utter_default")
            return [UserUtteranceReverted()] 
開發者ID:RasaHQ,項目名稱:rasa-demo,代碼行數:23,代碼來源:actions.py


注:本文中的rasa_sdk.Tracker方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。