Dataify YouTube Audio By URL
Submit YouTube audio file collection jobs through Dataify Builder by URL. After a successful submission, give the user the task_id, the returned or inferred status, and tell them to visit Dataify to view results.
API TOKEN Handling
Use DATAIFY_API_TOKEN as the long-term saved token name.
- If the user provides a token in the request, use it for this run.
- If no token is provided, first check whether
DATAIFY_API_TOKENis already saved locally in the environment. - If
DATAIFY_API_TOKENis saved locally, use it without asking the user to re-enter the token. - If no token is available locally, tell the user they need to provide a Dataify API TOKEN.
- If the user does not have an API TOKEN, tell them they can register or log in at Dataify to get one.
- If the user already has an API TOKEN, tell them it is available in the top-right area of Dataify.
- After the user provides an API TOKEN and no local
DATAIFY_API_TOKENis saved, ask whether they want to save it locally asDATAIFY_API_TOKENfor future use. - If the user wants to save it, give the appropriate command for their shell and ask them to run it; do not silently persist tokens without confirmation.
- Do not call the Builder endpoint without a token.
- Always call it
API TOKENin user-facing instructions. Prefer the environment variable nameDATAIFY_API_TOKENfor 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")
Core Workflow
- Before submitting, show the user the required values, shared values, optional values, and defaults listed in the Parameter Checklist.
- For dropdown fields, show all allowed options as Markdown tables with both
LabelandValuecolumns. Usescripts/submit_dataify_youtube_audio_by_url.py --list-optionsto print the full dropdown tables. - Ask whether the user wants to change any value before running the task.
- Ask whether the user wants to collect multiple YouTube audio files. If yes, ask for multiple
urlvalues. - Normalize the final
urlvalues into a list ofspider_parametersobjects. - Normalize
bitrate,audio_format,subtitles_language,kilohertz,is_subtitles, andselected_onlyinto one sharedspider_universalobject. - Resolve the Dataify token from explicit input or saved
DATAIFY_API_TOKEN. - If no token is available, ask the user to enter their API TOKEN and ask whether to save it as
DATAIFY_API_TOKEN. - Validate each URL, dropdown value, kilohertz direction, bitrate direction, and file name.
- Submit a Builder request to create the task.
- Read
data.task_idfrom the Builder response and readdata.statusorstatuswhen present. - Stop after Builder succeeds.
- Tell the user to visit Dataify to view or manage results.
Parameter Checklist
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 | Location | Notes |
| --- | --- | --- | --- | --- |
| url | Yes | https://www.youtube.com/watch?v=_SdpvpvVrLY | spider_parameters | YouTube URL to collect. |
| kilohertz | No | 48000 with <= | spider_universal | Dropdown-style shared parameter. Ask whether it should be greater than or equal to, or less than or equal to, the selected value. Submit as <=48000 by default. |
| audio_format | No | opus | spider_universal | Dropdown-style shared parameter. Audio format: opus or m4a. |
| bitrate | No | 320 with <= | spider_universal | Dropdown-style shared parameter. Ask whether it should be greater than or equal to, or less than or equal to, the selected value. Submit as <=320 by default. |
| subtitles_language | No | ab | spider_universal | Dropdown-style shared parameter. Subtitle language. |
| is_subtitles | No | false | spider_universal | Shared parameter. Whether to include subtitles. |
| selected_only | No | false | spider_universal | Dropdown-style shared parameter. Whether to use only selected specifications. |
| 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 audio files? If yes, provide multiple url values."
For kilohertz and bitrate, ask whether the selected option should use <= or >=. Default to <= when the user does not specify a direction.
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.
Dropdown Options
Before asking the user to choose dropdown values, show all allowed options as Markdown tables with both Label and Value columns.
Use this command to print the complete tables:
python3 ".\scripts\submit_dataify_youtube_audio_by_url.py" --list-options
If python3 is not available, use the local Python 3 command for that machine, such as python.
The script prints:
kilohertzoptions.kilohertz_directionoptions.audio_formatoptions.bitrateoptions.bitrate_directionoptions.subtitles_languageoptions, using the suppliedcnvalue asLabelandtypeValueasValue.is_subtitlesoptions.selected_onlyoptions.
Parameter Handling
urlis required. If the user does not provide it, use the defaulthttps://www.youtube.com/watch?v=_SdpvpvVrLYonly after showing it in the parameter confirmation table.- Trim leading and trailing whitespace from
url. urlcannot be empty.urlmust start withhttps://www.youtube.com/.- Multiple collection groups only repeat
urlinsidespider_parameters. bitrate,audio_format,subtitles_language,kilohertz,is_subtitles, andselected_onlyare shared parameters. Send them inspider_universal, not inside eachspider_parametersobject.kilohertzdefaults to48000andkilohertz_directiondefaults to<=; submitkilohertzas<=48000.bitratedefaults to320andbitrate_directiondefaults to<=; submitbitrateas<=320.audio_formatdefaults toopus. Allowed values areopusandm4a.subtitles_languagedefaults toab.is_subtitlesdefaults tofalse.selected_onlydefaults tofalse.file_namedefaults to{{TasksID}}. If the user changes it, submit the user-provided value.file_namecannot be empty.
Single-group example:
spider_parameters=[{"url":"https://www.youtube.com/watch?v=_SdpvpvVrLY"}]
spider_universal={"bitrate":"<=320","audio_format":"opus","subtitles_language":"ab","kilohertz":"<=48000","is_subtitles":"false","selected_only":"false"}
Multi-group example:
spider_parameters=[{"url":"https://www.youtube.com/watch?v=_SdpvpvVrLY"},{"url":"https://www.youtube.com/watch?v=_SdpvpvVrLY"}]
spider_universal={"bitrate":"<=320","audio_format":"opus","subtitles_language":"ab","kilohertz":"<=48000","is_subtitles":"false","selected_only":"false"}
Dataify Builder Request
Use form fields rather than hand-built URL-encoded strings.
- URL:
https://scraperapi.dataify.com/builder?platform=1 - Method:
POST - Authorization header:
Bearer DATAIFY_API_TOKEN - Content type:
application/x-www-form-urlencoded - Fixed fields:
spider_name=youtube.comspider_id=youtube_audio_by-urlspider_errors=true
- Default field:
file_name={{TasksID}}
- Dynamic fields:
spider_parametersmust be a JSON string array of URL objects.spider_universalmust be a JSON string object containing shared audio settings.
Script
For stable execution, prefer scripts/submit_dataify_youtube_audio_by_url.py with Python 3.6 or newer instead of rewriting the Builder flow.
python3 ".\scripts\submit_dataify_youtube_audio_by_url.py" --url "https://www.youtube.com/watch?v=_SdpvpvVrLY"
To override the saved environment token or default shared parameters for one run:
python3 ".\scripts\submit_dataify_youtube_audio_by_url.py" --api-token "YOUR_DATAIFY_API_TOKEN" --url "https://www.youtube.com/watch?v=_SdpvpvVrLY" --kilohertz "48000" --kilohertz-direction "<=" --audio-format "opus" --bitrate "320" --bitrate-direction "<=" --subtitles-language "ab" --is-subtitles "false" --selected-only "false" --file-name "{{TasksID}}"
To submit multiple URLs:
python3 ".\scripts\submit_dataify_youtube_audio_by_url.py" --params-json '[{"url":"https://www.youtube.com/watch?v=_SdpvpvVrLY"},{"url":"https://www.youtube.com/watch?v=_SdpvpvVrLY"}]'
The script prints a JSON summary with task_id, status, parameters, spider_universal, file_name, dashboard_url, and message.
Troubleshooting
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 Dataify to get one. If they already have a token, tell them it is in the top-right area of Dataify.
url cannot be empty means the required YouTube URL is missing.
url must start with https://www.youtube.com/ means the URL is outside the allowed YouTube domain.
Unsupported kilohertz, Unsupported audio_format, Unsupported bitrate, Unsupported subtitles_language, Unsupported is_subtitles, or Unsupported selected_only means the value must be one of the allowed dropdown values.
Unsupported kilohertz_direction or Unsupported bitrate_direction means the value must be <= or >=.
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 array, spider_universal was not a JSON string object, or one spider_parameters object is missing url.
Missing task_id usually means the authorization header, token, spider_name, spider_id, spider_parameters, or spider_universal is wrong.
Guardrails
- Do not put
bitrate,audio_format,subtitles_language,kilohertz,is_subtitles, orselected_onlyinsidespider_parameters. - Do not omit
spider_universal. - Do not poll for results after Builder succeeds.
- Use only
API TOKENandDATAIFY_API_TOKENwhen referring to authentication. - Do not hard-code local Python paths.
- Do not claim the Builder response contains YouTube audio files.
- Do not invent result fields.
- Always direct the user to Dataify after successful task creation.
微信扫一扫