Use the Python SDK for typed sync or async access to Xquik from scripts, notebooks, workers, agent tools, and backend services. Use this page when you need Python to search tweets, scrape tweets to CSV, JSON Lines, or XLSX, export followers, post tweets, upload media, send direct messages, monitor tweets, or hand X data to pandas, a warehouse, a queue, CRM, or an agent workflow.Documentation Index
Fetch the complete documentation index at: https://docs.xquik.com/llms.txt
Use this file to discover all available pages before exploring further.
Install
Authenticate
Basic Example
Search tweets and write durable JSON Lines handoff rows:Workflow: Search Tweets to CSV, JSON Lines, or XLSX
This job is for data scripts, notebooks, scheduled workers, and agent tools that need tweet search results in a durable handoff file. It callsGET /x/tweets/search through client.x.tweets.search, uses the generated TweetSearchParams shape, and writes analyst-friendly CSV plus JSON Lines for queues, warehouses, and replayable processing.
q
Python argument
q maps to REST q. Use it for the required X search query with keywords, handles, hashtags, or operators.limit
Python argument
limit maps to REST limit. Use it for a bounded request from 1 to 200. Omit it for cursor loops.cursor
Python argument
cursor maps to REST cursor. Pass the opaque cursor from page.next_cursor to request the next page.since_time
Python argument
since_time maps to REST sinceTime. Use it as the ISO 8601 lower time bound.until_time
Python argument
until_time maps to REST untilTime. Use it as the ISO 8601 upper time bound.query_type
Python argument
query_type maps to REST queryType. Use Latest for chronological results or Top for engagement-ranked results.Returned Data & Handoff
client.x.tweets.search returns a PaginatedTweets Pydantic model:
page.tweets
JSON field
tweets. Contains SearchTweet records with id, text, optional author, created_at, like_count, reply_count, retweet_count, quote_count, bookmark_count, view_count, and is_note_tweet when available.page.has_next_page
Python field
page.has_next_page. JSON field has_next_page. Tells your script whether another page exists.page.next_cursor
JSON field
next_cursor. Store it with the job checkpoint and pass it back as cursor.page.tweets to CSV for analysts. Write JSON Lines for queues and data lakes to xquik-tweet-search.jsonl with tweet.to_json(indent=None), or use .to_dict() records before loading a warehouse. Load the projected rows into pandas or openpyxl when account teams need an XLSX workbook. Pass id, text, author.username, created_at, and engagement counts to a CRM or enrichment job.
Workflow: Tweet Replies to CSV, JSON, or XLSX
Use this workflow when a Python script, notebook, worker, or agent tool needs every reply under one tweet as a saved extraction, JSON Lines handoff, or CSV/JSON/XLSX file export. It callsPOST /extractions/estimate through client.extractions.estimate_cost, creates the job with client.extractions.run, reads rows with client.extractions.retrieve, and downloads files with client.extractions.export_results.
reply_extractor requires target_tweet_id. client.extractions.retrieve returns results, has_more, and next_cursor; store those values when you need resumable JSON pagination. client.extractions.export_results supports csv, json, and xlsx for file handoff. Cost: 1 credit per reply extracted or returned.
Workflow: Post Media Tweets and DM Attachments
Use this workflow when a Python worker, notebook, support queue, or agent needs to post a media-backed tweet, reply with media, or send one uploaded media item in a DM. Tweet and reply media posts use public media URLs directly onclient.x.tweets.create. Send up to 4 image URLs or exactly 1 MP4 video URL up to 100 MB. Do not mix video with other media. Do not upload first when the media URL is already public.
tweet_id responses. Use with_raw_response.create when a write worker must branch on the REST 202 x_write_unconfirmed response, store writeActionId, and poll Get Write Action Status before sending another write.
reply_to_tweet_id:
media.media_id as the only media_ids item:
client.x.tweets.create returns tweet.tweet_id for confirmed posts. Raw create responses can also include the pending write fields above when confirmation is still running. client.x.media.upload returns media.media_id for DM attachments, and client.x.dm.send returns dm.message_id for support tickets, CRM records, queue jobs, or agent memory.
Each tweet or reply write costs 10 credits. Uploading media costs 10 credits, and sending the DM costs 10 credits. Do not pass uploaded media.media_id values to client.x.tweets.create; that method uses media with public media URLs.
Cost, Limits & Retries
Tweet search costs 1 credit per tweet returned. If remaining credits cannot cover a boundedlimit request, the API can return fewer tweets; if 0 paid results are affordable, it returns 402 insufficient_credits. Read calls are rate-limited, and 429 responses include Retry-After.
The client retries connection errors, 408, 409, 429, and 5xx responses by default. Handle RateLimitError with backoff, and fix 400, 401, 403, 404, or 422 responses before retrying.
Error Handling
All SDK exceptions inherit fromx_twitter_scraper.APIError.
400 Bad Request
Throws
BadRequestError.401 Unauthenticated
Throws
AuthenticationError.403 Permission Denied
Throws
PermissionDeniedError.404 Not Found
Throws
NotFoundError.422 Unprocessable Entity
Throws
UnprocessableEntityError.429 Rate Limited
Throws
RateLimitError.5xx Server Error
Throws
InternalServerError.max_retries when constructing the client to change retry behavior.
Pagination
List endpoints return page models withhas_next_page and cursor fields.