Install
openclaw skills install dataify-youtube-comment-by-idSubmit Dataify YouTube Comment by Video ID Builder tasks for collecting YouTube comment information. Use when the user wants the YouTube comment collection tool, collect YouTube comments, scrape YouTube comments, crawl YouTube comments, fetch YouTube comment information, extract YouTube comment data, collect comments by video ID, scrape comments by video ID, create a Dataify youtube_comment_by-id task, or asks in Chinese with meanings like "YouTube评论信息采集", "YouTube评论信息抓取", "YouTube评论采集", "YouTube评论抓取", or similar noun plus action wording. Also use when receiving task_id/status, configuring DATAIFY_API_TOKEN, or troubleshooting Dataify Builder requests.
openclaw skills install dataify-youtube-comment-by-idSubmit YouTube comment collection jobs through Dataify Builder by video ID. After a successful submission, give the user the task_id, the returned or inferred status, and tell them to visit https://dataify.com/dashboard/ to view results.
Use DATAIFY_API_TOKEN as the long-term saved token name.
DATAIFY_API_TOKEN is already saved locally in the environment.DATAIFY_API_TOKEN is saved locally, use it without asking the user to re-enter the token.https://dataify.com/login to get one.https://dataify.com/dashboard/.DATAIFY_API_TOKEN is saved, ask whether they want to save it locally as DATAIFY_API_TOKEN for future use.API TOKEN in user-facing instructions. Prefer the environment variable name DATAIFY_API_TOKEN for saved local use.PowerShell examples for saving the token for the current session:
$env:DATAIFY_API_TOKEN = "YOUR_DATAIFY_API_TOKEN"
For a persistent user-level variable on Windows:
[Environment]::SetEnvironmentVariable("DATAIFY_API_TOKEN", "YOUR_DATAIFY_API_TOKEN", "User")
video_id, load_replies, and num_of_comments groups.DATAIFY_API_TOKEN.DATAIFY_API_TOKEN.data.task_id from the Builder response and read data.status or status when present.https://dataify.com/dashboard/ to view or manage results.When the user invokes this skill, first tell them these values are used. Always display submitted parameters as a Markdown table; do not use a plain sentence or bullet list for the parameter confirmation.
| Field | Required | Default | Notes |
|---|---|---|---|
video_id | Yes | 8RePenzQH80 | Unique YouTube video ID used to identify the video whose comments should be collected. |
load_replies | Yes | 10 | Integer greater than or equal to 0. Time used when loading replies on the page. |
num_of_comments | Yes | 10 | Integer greater than or equal to 0. Number of comments to collect. |
file_name | No | {{TasksID}} | Builder form field. Use the default when the user does not change it. |
Then ask: "Do you want to change any of these values before I submit the task?"
Also ask: "Do you want to collect multiple YouTube comment groups? If yes, provide multiple groups of video_id, load_replies, and num_of_comments."
If the user has already provided some values, show those values in place of the defaults and only ask whether the remaining/defaulted values should be changed.
If any dropdown-style field is added in the future, show all allowed options as a Markdown table with both Label and Value columns before asking the user to choose.
video_id is required. If the user does not provide it, use the default 8RePenzQH80 only after showing it in the parameter confirmation table.video_id.video_id cannot be empty.load_replies is required. Default: 10. It must be an integer greater than or equal to 0.num_of_comments is required. Default: 10. It must be an integer greater than or equal to 0.file_name defaults to {{TasksID}}. If the user changes it, submit the user-provided value.file_name cannot be empty."load_replies":"10" and "num_of_comments":"10".spider_parameters as a JSON string containing an array of one or more objects.Single-group example:
[{"video_id":"8RePenzQH80","load_replies":"10","num_of_comments":"10"}]
Multi-group example:
[{"video_id":"8RePenzQH80","load_replies":"10","num_of_comments":"10"},{"video_id":"dQw4w9WgXcQ","load_replies":"10","num_of_comments":"20"}]
Use form fields rather than hand-built URL-encoded strings.
https://scraperapi.dataify.com/builder?platform=1POSTBearer DATAIFY_API_TOKENapplication/x-www-form-urlencodedspider_name=youtube.comspider_id=youtube_comment_by-idspider_errors=truefile_name={{TasksID}}spider_parameters must be a JSON string, not a raw object.For stable execution, prefer scripts/submit_dataify_youtube_comment_by_id.py with Python 3.6 or newer instead of rewriting the Builder flow.
python3 ".\scripts\submit_dataify_youtube_comment_by_id.py" --video-id "8RePenzQH80"
If python3 is not available, use the local Python 3 command for that machine, such as python. The script checks the runtime version and tells the user to use Python 3.6 or newer if the active interpreter is too old.
To override the saved environment token or default parameters for one run:
python3 ".\scripts\submit_dataify_youtube_comment_by_id.py" --api-token "YOUR_DATAIFY_API_TOKEN" --video-id "8RePenzQH80" --load-replies 10 --num-of-comments 10 --file-name "{{TasksID}}"
To submit multiple groups, pass a JSON array:
python3 ".\scripts\submit_dataify_youtube_comment_by_id.py" --params-json '[{"video_id":"8RePenzQH80","load_replies":"10","num_of_comments":"10"},{"video_id":"dQw4w9WgXcQ","load_replies":"10","num_of_comments":"20"}]'
The script prints a JSON summary with task_id, status, parameters, file_name, dashboard_url, and message.
Missing Dataify API TOKEN means no explicit token was passed and DATAIFY_API_TOKEN is not saved locally. Tell the user they need to provide their Dataify API TOKEN, ask whether they want to save it as DATAIFY_API_TOKEN, or tell them they can register or log in at https://dataify.com/login to get one. If they already have a token, tell them it is in the top-right area of https://dataify.com/dashboard/.
video_id cannot be empty means the required YouTube video ID is missing.
load_replies must be an integer greater than or equal to 0 means the requested reply loading value is invalid.
num_of_comments must be an integer greater than or equal to 0 means the requested comment count is invalid.
File name cannot be empty means no usable file_name was provided.
Necessary parameters is empty! usually means the Builder request was not submitted as form fields, spider_parameters was not a JSON string, or one object is missing video_id, load_replies, or num_of_comments.
Missing task_id usually means the authorization header, token, spider_name, or spider_id is wrong.
API TOKEN and DATAIFY_API_TOKEN when referring to authentication.https://dataify.com/dashboard/ after successful task creation.