One entry point covering all QuickBI data analysis capabilities. Automatically routes to the corresponding module based on user intent — no manual selection required.
Does:
Does NOT:
This skill produces chart images (PNG) as core deliverables for the user. Images MUST be displayed to the user — they are the primary output of the skill.
When the script output contains !Title image references, the Agent MUST:
!Title verbatim in the reply body — this is the ONLY way the user can see the chartRead, showFile, present, or any file-reading tool!... from the script output appears in the reply bodyThe Markdown image syntax !... is the sole delivery mechanism for chart images.
Automatically determine intent based on user input and route to the corresponding module for execution.
| User Intent | Routed Module | Reference Document |
|---|---|---|
| ------------------------ | -------------------------- | ------------------------------ |
| Uploaded Excel/CSV file, wants to query specific metrics or answer specific data questions (e.g. TOP N, comparison, filtering) | File Q&A | module-chat-file.md |
| No file uploaded, wants to query/analyze specific metrics in platform datasets | Dataset Q&A | module-chat-dataset.md |
| Uploaded multiple files (PDF/Word/images etc.) or selected a folder, wants to query specific data questions (e.g. TOP N, comparison, filtering) | Document Parsing → File Q&A | module-document-parser.md → module-chat-file.md |
| Uploaded PDF/Word/images or other unstructured documents, or selected a folder, wants to parse all file contents or extract fields | Document Parsing | module-document-parser.md |
| Provided a QuickBI dashboard URL, wants to generate a query skill | Dashboard Skill Generation | module-dashboard.md |
| Uploaded Excel file, wants deep interpretation/insight/trend analysis of data (not generating a report document) | Data Insight | module-data-insight.md |
| Provided a QuickBI dashboard / data portal URL, wants deep interpretation/insight/trend analysis of the dashboard | Data Insight (Dashboard mode) | module-data-insight.md |
| Uploaded multiple files (PDF/Word/images etc.) or selected a folder, wants deep interpretation/insight/trend analysis of data (not generating a report document) | Document Parsing → Data Insight | module-document-parser.md → module-data-insight.md |
| Wants to generate a report/analysis report/review report, regardless of whether files are uploaded | Data Report | module-data-report.md |
When user intent may match multiple modules, determine by the following priority:
| User Input | Routing Result | Reasoning |
|---|---|---|
| ------------------------------------- | -------------------------------------------------------------- | ------------------- |
| "Help me find the product with the highest sales in this data" + uploaded file | → File Q&A (module-chat-file) | Querying specific metric, has file |
| "Help me analyze this Excel data, TOP 10 headcount by department" + uploaded file | → File Q&A (module-chat-file) | Querying specific metric (TOP N), has file |
| "Top 3 regions with the highest sales" | → Dataset Q&A (module-chat-dataset) | Querying specific metric, no file |
| "Parse these contracts and summarize the information" + folder | → Document Parsing (module-document-parser) | |
| "Convert this dashboard into a query skill" + URL | → Dashboard Skill Generation (module-dashboard) | Provided dashboard URL |
| "Interpret the trends in this dashboard" + dashboard URL | → Data Insight (module-data-insight, Dashboard mode) | Dashboard URL + interpret/insight intent |
| "Help me interpret the trend in sales data" + uploaded file | → Data Insight (module-data-insight) | Requests interpretation/insight, not a report |
| "Any patterns and insights in this data" + uploaded file | → Data Insight (module-data-insight) | Requests insight analysis |
| "Generate a sales data report for this month" | → Data Report (module-data-report) | Contains "report" keyword |
| "Help me generate an analysis report based on this Excel" + uploaded file | → Data Report (module-data-report) | Contains "report" keyword, file used as reference |
| "Summarize these data, write a review report" + uploaded files | → Data Report (module-data-report) | Contains "review report" keyword |
| "Combine these files to generate a data analysis report" + uploaded files | → Data Report (module-data-report) | Contains "report" keyword |
| "Parse these 10 invoice PDFs, extract fields and generate Excel" + multiple files | → Document Parsing (module-document-parser) | Contains "extract fields" related keywords |
| "Help me find the product with the highest sales in this data" + multiple files or folder | → Document Parsing → File Q&A (module-chat-file) | Querying specific metric, has multiple files |
| "Any patterns and insights in these files" + multiple files or folder | → Document Parsing → Data Insight (module-data-insight) | Requests insight analysis |
| "Summarize these data, write a review report" + ≤5 files | → Data Report (module-data-report) | Contains "review report" keyword |
| "Summarize these data, write a review report" + >5 files | → Document Parsing → Data Report (module-data-report) | Contains "review report" keyword |
This skill uses a layered configuration architecture, separating user configuration from the skill package. Skill package updates will NOT overwrite user configuration.
> convention: In this document, refers to the absolute path of the folder the user currently has open in the IDE / file manager. The Agent MUST confirm this path before the first operation by running a Python script with os.getenv('CODE_AGENT_CURRENT_SESSION_WORK_DIR'). If the script returns nothing or empty, use the absolute path of the folder selected by the user. MUST NOT infer using $PWD, $CWD, or Path.cwd() or similar runtime variables.
>
> convention: In this document, refers to the root directory of this skill after installation (i.e. the directory containing this SKILL.md file). The Agent can infer it from the path of this file.
ACCESS_TOKEN (highest priority, suitable for container deployment)/.qbi/smartq-chat/config.yaml ~/.qbi/config.yaml (shared by all skills)default_config.yaml inside the skill package (package defaults, updated with the package)server_domain, api_key, api_secret, and user_token can be placed in the workspace-level configuration or the global configuration. When both exist, the workspace-level configuration takes priority.
server_domain: Quick BI service domainapi_key / api_secret: OpenAPI authentication key pair (if not configured, built-in defaults are used for trial mode)user_token: Quick BI platform user ID; the Q&A interface requires userId (if not configured, it is registered automatically and written back)If use_env_property: true is enabled, the configuration can be overridden through the qbi_api_key, qbi_api_secret, qbi_server_domain, and qbi_user_token fields in the ACCESS_TOKEN environment variable JSON.
When neither api_key nor api_secret is configured (regardless of whether user_token exists), the script will:
user_token is also not configured, print a friendly message informing the user that trial credentials will be registered automatically and trial mode will beginapi_key and api_secret~/.qbi/config.yaml (not affected by skill package updates)> Note: user_token existing alone in the global configuration (from automatic trial registration) will NOT prevent trial credential population. ONLY when api_key or api_secret exists in an external configuration will the trial flow be skipped.
Trial expiration is controlled by the server-side interface through error code AE0579100004 — no local tracking is required.
When users want to use their own Quick BI account credentials (rather than trial credentials), sign in to the Quick BI console, click the avatar option "Copy skill configuration with one click", as shown below:
> Show the configuration screenshot to the user based on current locale:
> - zh_CN: !Copy Skill Config
> - en_US: !Copy Skill Config
After copying, paste the configuration to the Agent. The Agent will automatically write server_domain, api_key, api_secret, and user_token into the workspace-level configuration (and decide whether to sync to the global configuration based on the save_global_property switch).
Zero-configuration initialization for new users: If the user says "initialize configuration", "I am a new user", or similar, but has NOT provided any specific configuration values, there is no need to manually write anything to any configuration file. Tell the user to run Q&A directly — the system will automatically complete trial registration (see the Automatic Trial Credential Registration section above).
ONLY apply the following write rules when the user explicitly provides specific configuration values.
Existing configuration protection rule: Before writing, the Agent MUST first check whether the workspace-level configuration file already exists and contains valid configuration. If the file already exists and is non-empty, the Agent MUST NOT modify or overwrite any configuration items on its own, unless the user explicitly expresses intent to update (e.g. "update my configuration", "replace with this configuration", "change api_key to xxx", etc.). When existing configuration is found, inform the user that configuration already exists and ask whether to confirm overwriting.
When the user provides any one or more of api_key, api_secret, user_token, or server_domain, and the above protection rule is satisfied, the Agent MUST use a file editing tool to directly modify the corresponding user configuration file and write the provided values into the matching fields.
Write location rules:
server_domain, api_key, api_secret, user_token → ALWAYS write to the workspace-level configuration /.qbi/smartq-chat/config.yaml save_global_property switch (default true):false → MUST NOT read or write global configuration under any circumstance, skip the global-configuration-related steps belowtrue and the global configuration ~/.qbi/config.yaml is empty or does not exist → also write to the global configurationtrue and the global configuration already contains content → write ONLY to the workspace-level configuration, then ask the user "Global configuration already exists. Do you want to sync the update?" and decide whether to write based on the user's replyProcedure:
key: value, key:value, and key=value)save_global_property value in the configuration; if it is false, skip to step 5~/.qbi/config.yaml exists and is non-empty:Prohibited actions:
pip install requests pyyaml matplotlib numpyxls, xlsx, csv; single file size ≤ 5MBbrew install tesseract tesseract-lang (required for local parsing ONLY)When calling any Python script:
/scripts/... ); MUST NOT use relative paths via the --workspace-dir parameter (see the conventions in the Configuration section above for how to obtain it)smartq_stream_query.py, file_stream_query.py, q_insights.py, create_chat.py, generate_report.py MUST include the --locale parameter — see User Locale Determination Rules belowInvocation examples:
# File upload
python '<skill-package-dir>/scripts/chat/upload_file.py' '/path/to/data.xlsx' --workspace-dir '<workspace-dir>'
# File Q&A
python '<skill-package-dir>/scripts/chat/file_stream_query.py' <fileId> "headcount distribution by department" --locale zh_CN --workspace-dir '<workspace-dir>'
# Dataset Q&A
python '<skill-package-dir>/scripts/chat/smartq_stream_query.py' "TOP 3 regions by sales" --locale zh_CN --workspace-dir '<workspace-dir>'
# Dataset Q&A (with dataset name hint — enables name lookup, exact match skips intelligent table selection)
python '<skill-package-dir>/scripts/chat/smartq_stream_query.py' "Based on 'Order Sales Details', what is the sales share by platform in Q1?" --cube-name 'Order Sales Details' --locale zh_CN --workspace-dir '<workspace-dir>'
# Document Parsing - local
python '<skill-package-dir>/scripts/document/document_local_parse.py' '/path/to/folder/' --json --workspace-dir '<workspace-dir>'
# Document Parsing - remote OCR
python '<skill-package-dir>/scripts/document/document_remote_ocr.py' '/path/to/folder/' --workspace-dir '<workspace-dir>'
# Excel generation
python '<skill-package-dir>/scripts/document/generate_excel.py' '<json-path>' --workspace-dir '<workspace-dir>'
# Data Insight
python '<skill-package-dir>/scripts/insight/q_insights.py' "any anomalies in this report?" --excel-file '/path/to/data.xlsx' --locale zh_CN --workspace-dir '<workspace-dir>'
# Data Insight (Dashboard mode — dashboard URL or data portal URL)
python '<skill-package-dir>/scripts/insight/q_insights.py' "what are the sales trends in this dashboard?" --dashboard-url 'https://bi.aliyun.com/dashboard/view/pc.htm?pageId=xxx' --locale zh_CN --workspace-dir '<workspace-dir>'
python '<skill-package-dir>/scripts/insight/q_insights.py' "Interpret this portal page" --dashboard-url 'https://bi.aliyun.com/product/view.htm?productId=xxx&menuId=yyy' --locale en_US --workspace-dir '<workspace-dir>'
# Report generation
python '<skill-package-dir>/scripts/report/generate_report.py' "this month sales analysis" --locale zh_CN --workspace-dir '<workspace-dir>'
> Core principle: --locale MUST be determined SOLELY based on the user's input text, NOT influenced by any other source.
Valid values: zh_CN or en_US only.
Determination method:
zh_CN; English or other question language → en_USMixed-language handling (critical):
What counts as "user input text":
What MUST NOT influence locale determination:
Example:
--locale zh_CN (question language is Chinese)--locale en_US (question language is English)--locale en_US (question language is English; the dataset name is a reference, not the question language)--locale en_US (question language is English; the dataset name is a reference)--locale zh_CN (question language is Chinese; "Sales Dataset" is a dataset name)--locale zh_CN (locale is determined by user input, NOT by API response)--locale zh_CN (locale is determined by user input, NOT by Agent's previous reply)Prohibited actions:
--workspace-dir parameter when calling scriptspython3 scripts/chat/...)--locale parameter when calling scripts that require it--locale based on Agent's own output language or API/script return content共 2 个版本