# text=message["content"]=<tool_call>\n{\"name\": \"mobile_use\", \"arguments\": {\"action\": \"system_button\", \"button\": \"Back\"}}\n</tool_call>\n<conclusion>\nGo back to the previous screen\n</conclusion>
text="<tool_call>\n{\"name\": \"mobile_use\", \"arguments\": {\"action\": \"open_app\", \"text\": \"Drive\"}}\n</tool_call>\n<conclusion>\nOpen the google drive app\n</conclusion>"
import re
import json
def parse_action(text):

    pattern = r'<tool_call>\s*([\s\S]*?)\s*</tool_call>'
    match = re.search(pattern, text)
    if match:
        result = match.group(1).strip()
        result = json.loads(result)
        print(result)
    else:
        print("未找到匹配内容")

    action_type=result["arguments"]["action"]
    param_dict={}
    if action_type== "system_button":
        param_dict["text"]=result["arguments"]["button"]
    if action_type== "swipe":
        param_dict['from_coord']=result["arguments"]["coordinate"]
        param_dict['to_coord']=result["arguments"]["coordinate2"]
    if action_type== "click":
        param_dict['x'] = result["arguments"]["coordinate"][0]
        param_dict['y'] = result["arguments"]["coordinate"][1]
    if action_type== "open_app":
        param_dict['text'] = result["arguments"]["text"]
    if action_type== "wait":
        param_dict['text'] = result["arguments"]["time"]
    if action_type== "write":
        param_dict['text'] = result["arguments"]["text"]
    if action_type== "long_press":
        param_dict['x'] = result["arguments"]["coordinate"][0]
        param_dict['y'] = result["arguments"]["coordinate"][1]
        param_dict['text'] = result["arguments"]["time"]

    return {'action_type': action_type, 'params': param_dict}

print(parse_action(text))
# resized_width=0
# resized_height=1
# QWEN25VL_SYS="""You are a helpful assistant.\n\n# Tools\n\nYou may call one or more functions to assist with the user query.\n\nYou are provided with function signatures within <tools></tools> XML tags:\n<tools>\n{\"type\": \"function\", \"function\": {\"name_for_human\": \"mobile_use\", \"name\": \"mobile_use\", \"description\": \"Use a touchscreen to interact with a mobile device, and take screenshots.\\n* This is an interface to a mobile device with touchscreen. You can perform actions like clicking, typing, swiping, etc.\\n* Some applications may take time to start or process actions, so you may need to wait and take successive screenshots to see the results of your actions.\\n* The screen's resolution is {weight}x{height}.\\n* Make sure to click any buttons, links, icons, etc with the cursor tip in the center of the element. Don't click boxes on their edges unless asked.\", \"parameters\": {\"properties\": {\"action\": {\"description\": \"The action to perform. The available actions are:\\n* `key`: Perform a key event on the mobile device.\\n    - This supports adb's `keyevent` syntax.\\n    - Examples: \\\"volume_up\\\", \\\"volume_down\\\", \\\"power\\\", \\\"camera\\\", \\\"clear\\\".\\n* `click`: Click the point on the screen with coordinate (x, y).\\n* `long_press`: Press the point on the screen with coordinate (x, y) for specified seconds.\\n* `swipe`: Swipe from the starting point with coordinate (x, y) to the end point with coordinates2 (x2, y2).\\n* `type`: Input the specified text into the activated input box.\\n* `system_button`: Press the system button.\\n* `open`: Open an app on the device.\\n* `wait`: Wait specified seconds for the change to happen.\\n* `terminate`: Terminate the current task and report its completion status.\", \"enum\": [\"key\", \"click\", \"long_press\", \"swipe\", \"type\", \"system_button\", \"open\", \"wait\", \"terminate\"], \"type\": \"string\"}, \"coordinate\": {\"description\": \"(x, y): The x (pixels from the left edge) and y (pixels from the top edge) coordinates to move the mouse to. Required only by `action=click`, `action=long_press`, and `action=swipe`.\", \"type\": \"array\"}, \"coordinate2\": {\"description\": \"(x, y): The x (pixels from the left edge) and y (pixels from the top edge) coordinates to move the mouse to. Required only by `action=swipe`.\", \"type\": \"array\"}, \"text\": {\"description\": \"Required only by `action=key`, `action=type`, and `action=open`.\", \"type\": \"string\"}, \"time\": {\"description\": \"The seconds to wait. Required only by `action=long_press` and `action=wait`.\", \"type\": \"number\"}, \"button\": {\"description\": \"Back means returning to the previous interface, Home means returning to the desktop, Menu means opening the application background menu, and Enter means pressing the enter. Required only by `action=system_button`\", \"enum\": [\"Back\", \"Home\", \"Menu\", \"Enter\"], \"type\": \"string\"}, \"status\": {\"description\": \"The status of the task. Required only by `action=terminate`.\", \"type\": \"string\", \"enum\": [\"success\", \"failure\"]}}, \"required\": [\"action\"], \"type\": \"object\"}, \"args_format\": \"Format the arguments as a JSON object.\"}}\n</tools>\n\nFor each function call, return a json object with function name and arguments within <tool_call></tool_call> XML tags:\n<tool_call>\n{\"name\": <function-name>, \"arguments\": <args-json-object>}\n</tool_call>"""
# print(QWEN25VL_SYS.format(weight=resized_width,height=resized_height))