# Goofish 闲鱼 Xianyu Item Comments Q\&A Scraper (`zen-studio/goofish-xianyu-item-comments-scraper`) Actor

Extract the buyer comment thread (留言) and Q\&A (问大家) from any Goofish (闲鱼/Xianyu) listing: buyer questions, seller replies, regions, post times, likes, and commenter names, with replies nested per comment. Export to JSON/CSV. Just add item URLs or IDs.

- **URL**: https://apify.com/zen-studio/goofish-xianyu-item-comments-scraper.md
- **Developed by:** [Zen Studio](https://apify.com/zen-studio) (community)
- **Categories:** E-commerce
- **Stats:** 2 total users, 1 monthly users, 100.0% runs succeeded, 0 bookmarks
- **User rating**: No ratings yet

## Pricing

from $4.29 / 1,000 comments

This Actor is paid per event. You are not charged for the Apify platform usage, but only a fixed price for specific events.
Since this Actor supports Apify Store discounts, the price gets lower the higher subscription plan you have.

Learn more: https://docs.apify.com/platform/actors/running/actors-in-store#pay-per-event

## What's an Apify Actor?

Actors are a software tools running on the Apify platform, for all kinds of web data extraction and automation use cases.
In Batch mode, an Actor accepts a well-defined JSON input, performs an action which can take anything from a few seconds to a few hours,
and optionally produces a well-defined JSON output, datasets with results, or files in key-value store.
In Standby mode, an Actor provides a web server which can be used as a website, API, or an MCP server.
Actors are written with capital "A".

## How to integrate an Actor?

If asked about integration, you help developers integrate Actors into their projects.
You adapt to their stack and deliver integrations that are safe, well-documented, and production-ready.
The best way to integrate Actors is as follows.

In JavaScript/TypeScript projects, use official [JavaScript/TypeScript client](https://docs.apify.com/api/client/js.md):

```bash
npm install apify-client
```

In Python projects, use official [Python client library](https://docs.apify.com/api/client/python.md):

```bash
pip install apify-client
```

In shell scripts, use [Apify CLI](https://docs.apify.com/cli/docs.md):

````bash
# MacOS / Linux
curl -fsSL https://apify.com/install-cli.sh | bash
# Windows
irm https://apify.com/install-cli.ps1 | iex
```bash

In AI frameworks, you might use the [Apify MCP server](https://docs.apify.com/platform/integrations/mcp.md).

If your project is in a different language, use the [REST API](https://docs.apify.com/api/v2.md).

For usage examples, see the [API](#api) section below.

For more details, see Apify documentation as [Markdown index](https://docs.apify.com/llms.txt) and [Markdown full-text](https://docs.apify.com/llms-full.txt).


# README

## Goofish Comments & Q&A Scraper (闲鱼 / Xianyu / Idlefish) | Buyer Questions + Seller Replies

![Goofish Comments & Q&A Scraper](https://iili.io/Cqrfiva.png)

<table style="width:100%">
<tr>
<td colspan="5" style="padding:10px 14px;background:#4C945E;border:none;border-radius:4px 4px 0 0">
<span style="color:#FAFAF9;font-size:14px;font-weight:700;letter-spacing:0.5px">Zen Studio China Scrapers</span>
<span style="color:#D7F4DD;font-size:13px">&nbsp;&nbsp;&bull;&nbsp;&nbsp;Goofish, JD.com, Taobao, and wholesale data</span>
</td>
</tr>
<tr>
<td style="padding:10px 14px;border:1px solid #E7E5E4;border-radius:0 0 0 4px;border-right:none;border-top:none;background:#E8F5E9;vertical-align:top;width:20%">
<span style="white-space:nowrap"><img src="https://apify-image-uploads-prod.s3.us-east-1.amazonaws.com/NWYsOG96fMDy8ycdf-actor-5QcLc4BHaLMBUKYs3-f3CWQ60Row-goofish-search-scraper-logo.png" width="20" height="20" style="vertical-align:middle;border-radius:4px"> &nbsp;<a href="https://apify.com/zen-studio/goofish-xianyu-item-comments-scraper" style="color:#4C945E;text-decoration:none;font-weight:700;font-size:13px">Goofish Comments</a></span><br>
<span style="color:#4C945E;font-size:11px;font-weight:600">&#10148; You are here</span>
</td>
<td style="padding:10px 14px;border:1px solid #E7E5E4;border-right:none;border-top:none;vertical-align:top;width:20%">
<span style="white-space:nowrap"><img src="https://apify-image-uploads-prod.s3.us-east-1.amazonaws.com/NWYsOG96fMDy8ycdf-actor-5QcLc4BHaLMBUKYs3-f3CWQ60Row-goofish-search-scraper-logo.png" width="20" height="20" style="vertical-align:middle;border-radius:4px"> &nbsp;<a href="https://apify.com/zen-studio/goofish-xianyu-search-scraper" style="color:#1C1917;text-decoration:none;font-weight:700;font-size:13px">Goofish Search</a></span><br>
<span style="color:#78716C;font-size:11px">Listings + sellers</span>
</td>
<td style="padding:10px 14px;border:1px solid #E7E5E4;border-right:none;border-top:none;vertical-align:top;width:20%">
<span style="white-space:nowrap"><img src="https://apify-image-uploads-prod.s3.us-east-1.amazonaws.com/NWYsOG96fMDy8ycdf-actor-5QcLc4BHaLMBUKYs3-f3CWQ60Row-goofish-search-scraper-logo.png" width="20" height="20" style="vertical-align:middle;border-radius:4px"> &nbsp;<a href="https://apify.com/zen-studio/goofish-xianyu-item-detail-scraper" style="color:#1C1917;text-decoration:none;font-weight:700;font-size:13px">Goofish Detail</a></span><br>
<span style="color:#78716C;font-size:11px">Full item detail</span>
</td>
<td style="padding:10px 14px;border:1px solid #E7E5E4;border-right:none;border-top:none;vertical-align:top;width:20%">
<span style="white-space:nowrap"><img src="https://apify-image-uploads-prod.s3.us-east-1.amazonaws.com/NWYsOG96fMDy8ycdf-actor-5QcLc4BHaLMBUKYs3-f3CWQ60Row-goofish-search-scraper-logo.png" width="20" height="20" style="vertical-align:middle;border-radius:4px"> &nbsp;<a href="https://apify.com/zen-studio/goofish-xianyu-seller-scraper" style="color:#1C1917;text-decoration:none;font-weight:700;font-size:13px">Sellers &amp; Reviews</a></span><br>
<span style="color:#78716C;font-size:11px">Profiles + reviews</span>
</td>
<td style="padding:10px 14px;border:1px solid #E7E5E4;border-radius:0 0 4px 0;border-top:none;vertical-align:top;width:20%">
<span style="white-space:nowrap"><img src="https://apify-image-uploads-prod.s3.us-east-1.amazonaws.com/NWYsOG96fMDy8ycdf-actor-PsAKYWM55HG4AHXjK-ItywU7Bp0s-taobao-search-scraper-logo.png" width="20" height="20" style="vertical-align:middle;border-radius:4px"> &nbsp;<a href="https://apify.com/zen-studio/taobao-search-scraper" style="color:#1C1917;text-decoration:none;font-weight:700;font-size:13px">Taobao</a></span><br>
<span style="color:#78716C;font-size:11px">Products + reviews</span>
</td>
</tr>
</table>

Extract the **public buyer comment thread (留言)** and **buyer Q&A (问大家)** from any Goofish (闲鱼 / Xianyu / Idlefish) listing. For each item you get every buyer question, the seller's public replies nested underneath, plus who asked, from where, when, and how many likes each comment has.

This is the closest thing Goofish has to per-listing buyer sentiment: what shoppers ask before buying, and how the seller responds. Point it at a competitor's hot listings, a category's top items, or your own shop.

### What you get

- **One row per top-level comment**, with the full **reply thread nested** under it.
- **Decrypted display names** for both the buyer and the seller (no raw identifiers).
- **`authorRole`** on every comment and reply — `seller` or `buyer` — so you can instantly separate questions from the shop's answers.
- **Region, post time, likes, and rank badges** per comment.
- **Buyer Q&A (问大家)** delivered to a separate `item-questions` dataset.

### Input

| Field | Type | Description |
|-------|------|-------------|
| `startUrls` | array | Goofish item URLs or raw item IDs, one per line (up to 1,000). Duplicates are skipped. |
| `maxCommentsPerItem` | integer | Max top-level comments per item. `0` = all. Default `100`. Nested replies never count toward this. |
| `includeReplies` | boolean | Include the nested reply thread under each comment. Default `true`. |
| `includeQuestions` | boolean | Also capture the buyer Q&A (问大家) into the `item-questions` dataset. Default `true`. |

Supported input formats:

- `https://www.goofish.com/item?id=947872178004`
- `947872178004`

```json
{
  "startUrls": ["947872178004", "https://www.goofish.com/item?id=933998278227"],
  "maxCommentsPerItem": 100,
  "includeReplies": true,
  "includeQuestions": true
}
````

### Output

#### Comments dataset (default)

One row per top-level comment. The seller's answers and any follow-ups are nested in `replies[]`.

```json
{
  "itemId": "933998278227",
  "commentId": "601455703803",
  "content": "你好，摄像头像素是多大",
  "level": 1,
  "authorRole": "buyer",
  "authorNick": "lzz开心",
  "region": "陕西",
  "regionFull": "中国陕西省",
  "authorAvatarUrl": "https://img.alicdn.com/bao/uploaded/avatar.png",
  "postedAt": "2025-11-20T23:21:31+08:00",
  "dateLabel": "25-11-20",
  "likes": 0,
  "isFeatured": false,
  "itemCommentTotal": 17,
  "replies": [
    {
      "commentId": "601440962807",
      "content": "200w",
      "level": 2,
      "authorRole": "seller",
      "authorNick": "智表数码",
      "replyToNick": "lzz开心",
      "parentCommentId": "601455703803",
      "region": "广东",
      "postedAt": "2025-11-20T23:25:10+08:00",
      "likes": 0,
      "rankBadgeUrl": "https://gw.alicdn.com/imgextra/badge.png"
    }
  ]
}
```

**Comment fields**

| Field | Description |
|-------|-------------|
| `itemId` | The listing this comment belongs to. |
| `commentId` | Stable comment identifier. |
| `content` | The comment text. |
| `level` | Thread depth (`1` = top-level). |
| `authorRole` | `seller` or `buyer`. |
| `authorNick` | Commenter display name. |
| `region` / `regionFull` | Commenter region (short / full). |
| `authorAvatarUrl` | Commenter avatar image. |
| `postedAt` / `dateLabel` | Post time (ISO +08:00 / short label). |
| `likes` | Likes on the comment. |
| `isFeatured` | Whether the comment is in the listing's featured/most-liked set. |
| `itemCommentTotal` | Total comments + replies on the listing. |
| `rankBadgeUrl` / `tagBadgeUrls` | Author rank / tag badge images, when present. |
| `replies[]` | Nested replies. Each carries `replyToNick` (who the reply addresses), `parentCommentId`, `parentCommenterNick`, and the same fields above. |

#### Q\&A dataset (`item-questions`)

When `includeQuestions` is on, the buyer Q\&A (问大家) for each item is written to a separate `item-questions` dataset:

```json
{ "itemId": "809415340549", "qid": "adade88cc0b74c0da8ad3b11c9b5da31", "question": "偏大还是偏小？", "answer": "偏小半码" }
```

#### Status rows

Inputs that can't be turned into comments come back as unbilled rows so nothing is silently dropped:

- `rowStatus: "invalid"` — the input was not a recognized Goofish item.
- `rowStatus: "unavailable"` — the listing is offline or removed.
- `rowStatus: "error"` — the listing could not be loaded.
- `rowStatus: "ok"` with `commentCount: 0` — the listing was read successfully and has no comments.

### Use cases

- **Competitor & shop monitoring** — track what buyers ask about a competitor's hot listings and how fast the seller responds.
- **Pre-purchase FAQ mining** — aggregate buyer questions across a category to surface the concerns that drive (or block) purchases: authenticity, sizing, returns, condition.
- **Seller responsiveness analysis** — measure answer rate and response quality from the nested `authorRole: seller` replies.
- **Listing-level sentiment** — the closest signal Goofish offers to per-item buyer feedback.

### Pricing — Pay Per Event (PPE)

You are charged **per top-level comment** returned. Nested replies are **free**. Buyer Q\&A is free on the first page per item; only overflow pages bill at the same rate.

| Plan | Price per 1,000 comments |
|------|--------------------------|
| Free / Bronze | $5.99 |
| Silver | $4.99 |
| Gold | $4.29 |

Invalid, unavailable, empty, and error status rows are **never charged**.

### FAQ

**Are these product reviews?**
No. Goofish has no per-listing star reviews. These are the public pre-purchase comment thread (留言) and buyer Q\&A (问大家). For seller-level transaction reviews, use the Goofish Seller Scraper.

**Do all listings have comments?**
No. Busy B2C listings carry dozens to hundreds; many casual listings have none. Empty listings return an unbilled status row.

**Are buyer and seller names included?**
Yes, as public display names.

**How do I get item IDs to feed in?**
Use the Goofish Search Scraper or Seller Scraper to collect listing IDs, then pass them here.

### More Zen Studio scrapers for Chinese platforms

**🛒 E-commerce**

- <img src="https://apify-image-uploads-prod.s3.us-east-1.amazonaws.com/NWYsOG96fMDy8ycdf-actor-5QcLc4BHaLMBUKYs3-f3CWQ60Row-goofish-search-scraper-logo.png" width="16" height="16" style="vertical-align:middle;border-radius:3px"> **Goofish 闲鱼**
  - [Goofish (Xianyu) Search Scraper](https://apify.com/zen-studio/goofish-xianyu-search-scraper)
  - [Goofish (Xianyu) Item Detail Scraper](https://apify.com/zen-studio/goofish-xianyu-item-detail-scraper)
  - [Goofish (Xianyu) Seller Scraper](https://apify.com/zen-studio/goofish-xianyu-seller-scraper)
- <img src="https://apify-image-uploads-prod.s3.us-east-1.amazonaws.com/NWYsOG96fMDy8ycdf-actor-PsAKYWM55HG4AHXjK-ItywU7Bp0s-taobao-search-scraper-logo.png" width="16" height="16" style="vertical-align:middle;border-radius:3px"> **Taobao 淘宝**
  - [Taobao Search Scraper](https://apify.com/zen-studio/taobao-search-scraper)
  - [Taobao Product Detail Scraper](https://apify.com/zen-studio/taobao-detail-scraper)
  - [Taobao Seller Products Scraper](https://apify.com/zen-studio/taobao-seller-products-scraper)
- <img src="https://apify-image-uploads-prod.s3.us-east-1.amazonaws.com/NWYsOG96fMDy8ycdf-actor-uZy6tbKLKnSVtT4BN-emXnT123uR-jd-com-scraper-logo-square.png" width="16" height="16" style="vertical-align:middle;border-radius:3px"> **JD.com 京东**
  - [JD.com Search Scraper](https://apify.com/zen-studio/jd-com-search-scraper)
- <img src="https://apify-image-uploads-prod.s3.us-east-1.amazonaws.com/NWYsOG96fMDy8ycdf-actor-ghXSMZcW3GxsCrkiR-5hnvsKv4Yt-1688-wholesale-scraper-logo.png" width="16" height="16" style="vertical-align:middle;border-radius:3px"> **1688 阿里巴巴**
  - [1688 Wholesale Scraper](https://apify.com/zen-studio/1688-wholesale-scraper)

**🎬 Short-video & social**

- <img src="https://apify-image-uploads-prod.s3.us-east-1.amazonaws.com/NWYsOG96fMDy8ycdf-actor-3TJaaOJDU1AMiOoJM-Vu2eVr0P6N-douyin-profile-scraper-logo.png" width="16" height="16" style="vertical-align:middle;border-radius:3px"> **Douyin 抖音**
  - [Douyin Search Scraper](https://apify.com/zen-studio/douyin-search-scraper)
  - [Douyin Profile Scraper](https://apify.com/zen-studio/douyin-profile-scraper)
  - [Douyin Video Scraper](https://apify.com/zen-studio/douyin-video-scraper)
  - [Douyin Comments Scraper](https://apify.com/zen-studio/douyin-comments-scraper)
  - [Douyin Transcripts Scraper](https://apify.com/zen-studio/douyin-transcripts-scraper)
  - [Douyin Creator Rankings Scraper](https://apify.com/zen-studio/douyin-xingtu-rankings-scraper)
  - [Douyin Live Recorder](https://apify.com/zen-studio/douyin-live-recorder)
  - [Douyin Hot Search Scraper](https://apify.com/zen-studio/douyin-hot-search-scraper)
- <img src="https://apify-image-uploads-prod.s3.us-east-1.amazonaws.com/NWYsOG96fMDy8ycdf-actor-mHKEEgoDqr6btQQer-fUs5ZquIeN-xiaohongshu-search-scraper-logo-square.png" width="16" height="16" style="vertical-align:middle;border-radius:3px"> **RedNote 小红书**
  - [RedNote User Profile Scraper](https://apify.com/zen-studio/rednote-user-profile-scraper)
  - [RedNote Search Scraper](https://apify.com/zen-studio/rednote-search-scraper)
  - [RedNote Comments Scraper](https://apify.com/zen-studio/rednote-comments-scraper)
  - [RedNote Product Search Scraper](https://apify.com/zen-studio/rednote-product-search-scraper)
  - [RedNote Note Detail Scraper](https://apify.com/zen-studio/rednote-note-detail-scraper)
  - [RedNote Product Reviews Scraper](https://apify.com/zen-studio/rednote-product-reviews-scraper)
  - [RedNote Live Recorder](https://apify.com/zen-studio/rednote-live-recorder)
- <img src="https://apify-image-uploads-prod.s3.us-east-1.amazonaws.com/NWYsOG96fMDy8ycdf-actor-dexCSKEZtKS8hg4fT-lD4weyiYga-shigua-____-scraper-logo.jpg" width="16" height="16" style="vertical-align:middle;border-radius:3px"> **Xigua 西瓜视频**
  - [Xigua Video Search Scraper](https://apify.com/zen-studio/xigua-video-search-scraper)
  - [Xigua Video Detail Scraper](https://apify.com/zen-studio/xigua-video-detail-scraper)

**🏠 Real estate & autos**

- <img src="https://apify-image-uploads-prod.s3.us-east-1.amazonaws.com/NWYsOG96fMDy8ycdf-actor-1tAzNSf8Kz0v7Q2Lr-AINJ7FsZVU-anjuke-scraper-logo.jpg" width="16" height="16" style="vertical-align:middle;border-radius:3px"> **Anjuke 安居客**
  - [Anjuke For-Sale Listings Scraper](https://apify.com/zen-studio/anjuke-real-estate-scraper)
  - [Anjuke New-Home Scraper](https://apify.com/zen-studio/anjuke-new-home-scraper)
  - [Anjuke Rental Listings Scraper](https://apify.com/zen-studio/anjuke-rent-scraper)
  - [Anjuke Listing Detail Scraper](https://apify.com/zen-studio/anjuke-sale-detail-scraper)
- <img src="https://apify-image-uploads-prod.s3.us-east-1.amazonaws.com/NWYsOG96fMDy8ycdf-actor-32OkWqsiUywoq2ci3-7JhFlW1qg3-58__-real-estate-scraper-logo.jpg" width="16" height="16" style="vertical-align:middle;border-radius:3px"> **58.com 58同城**
  - [58.com Real Estate Scraper](https://apify.com/zen-studio/58-real-estate-scraper)
- <img src="https://apify-image-uploads-prod.s3.us-east-1.amazonaws.com/NWYsOG96fMDy8ycdf-actor-ytaE4YpSmjXDmibPv-L1UMPHa2bO-che168-autohome-scraper-logo.png" width="16" height="16" style="vertical-align:middle;border-radius:3px"> **Autohome 汽车之家**
  - [Autohome (Che168) Used-Car Scraper](https://apify.com/zen-studio/che168-car-scraper)

### Support

Found a bug or need a field added? Open an issue on the actor's Issues tab.

### Legal Compliance

Scrape only publicly available data and use it in accordance with Goofish's terms and applicable laws (including data-protection regulations). You are responsible for how you use the data.

# Actor input Schema

## `startUrls` (type: `array`):

Add one item input per line.<br><br>Supported formats:<br>• <code>https://www.goofish.com/item?id=947872178004</code><br>• <code>947872178004</code><br>• Mobile share link: <code>https://m.tb.cn/h.XXXXXX?tk=YYYYYY</code> (from the app's Share button)<br><br>Up to <b>1,000 inputs per run</b>. Duplicate item IDs are skipped. Invalid inputs are returned as unbilled rows with <code>rowStatus: invalid</code>.

## `maxCommentsPerItem` (type: `integer`):

Maximum number of top-level comments to return per item. Set to <b>0</b> for all comments. Nested replies are always included and never count toward this limit.

## `includeReplies` (type: `boolean`):

Include the nested reply thread under each comment (the seller's public answers and follow-ups). Replies are always free.

## `includeQuestions` (type: `boolean`):

Also capture the buyer Q\&A thread into a separate <code>item-questions</code> dataset. The first page of Q\&A per item is free.

## Actor input object example

```json
{
  "startUrls": [
    "947872178004"
  ],
  "maxCommentsPerItem": 100,
  "includeReplies": true,
  "includeQuestions": true
}
```

# Actor output Schema

## `comments` (type: `string`):

Top-level comments with nested replies, plus unbilled status rows. Buyer Q\&A is in the separate item-questions dataset.

# API

You can run this Actor programmatically using our API. Below are code examples in JavaScript, Python, and CLI, as well as the OpenAPI specification and MCP server setup.

## JavaScript example

```javascript
import { ApifyClient } from 'apify-client';

// Initialize the ApifyClient with your Apify API token
// Replace the '<YOUR_API_TOKEN>' with your token
const client = new ApifyClient({
    token: '<YOUR_API_TOKEN>',
});

// Prepare Actor input
const input = {
    "startUrls": [
        "947872178004"
    ]
};

// Run the Actor and wait for it to finish
const run = await client.actor("zen-studio/goofish-xianyu-item-comments-scraper").call(input);

// Fetch and print Actor results from the run's dataset (if any)
console.log('Results from dataset');
console.log(`💾 Check your data here: https://console.apify.com/storage/datasets/${run.defaultDatasetId}`);
const { items } = await client.dataset(run.defaultDatasetId).listItems();
items.forEach((item) => {
    console.dir(item);
});

// 📚 Want to learn more 📖? Go to → https://docs.apify.com/api/client/js/docs

```

## Python example

```python
from apify_client import ApifyClient

# Initialize the ApifyClient with your Apify API token
# Replace '<YOUR_API_TOKEN>' with your token.
client = ApifyClient("<YOUR_API_TOKEN>")

# Prepare the Actor input
run_input = { "startUrls": ["947872178004"] }

# Run the Actor and wait for it to finish
run = client.actor("zen-studio/goofish-xianyu-item-comments-scraper").call(run_input=run_input)

# Fetch and print Actor results from the run's dataset (if there are any)
print("💾 Check your data here: https://console.apify.com/storage/datasets/" + run["defaultDatasetId"])
for item in client.dataset(run["defaultDatasetId"]).iterate_items():
    print(item)

# 📚 Want to learn more 📖? Go to → https://docs.apify.com/api/client/python/docs/quick-start

```

## CLI example

```bash
echo '{
  "startUrls": [
    "947872178004"
  ]
}' |
apify call zen-studio/goofish-xianyu-item-comments-scraper --silent --output-dataset

```

## MCP server setup

```json
{
    "mcpServers": {
        "apify": {
            "command": "npx",
            "args": [
                "mcp-remote",
                "https://mcp.apify.com/?tools=zen-studio/goofish-xianyu-item-comments-scraper",
                "--header",
                "Authorization: Bearer <YOUR_API_TOKEN>"
            ]
        }
    }
}

```

## OpenAPI specification

```json
{
    "openapi": "3.0.1",
    "info": {
        "title": "Goofish 闲鱼 Xianyu Item Comments Q&A Scraper",
        "description": "Extract the buyer comment thread (留言) and Q&A (问大家) from any Goofish (闲鱼/Xianyu) listing: buyer questions, seller replies, regions, post times, likes, and commenter names, with replies nested per comment. Export to JSON/CSV. Just add item URLs or IDs.",
        "version": "0.0",
        "x-build-id": "swmSSOz6s2ukrfHkI"
    },
    "servers": [
        {
            "url": "https://api.apify.com/v2"
        }
    ],
    "paths": {
        "/acts/zen-studio~goofish-xianyu-item-comments-scraper/run-sync-get-dataset-items": {
            "post": {
                "operationId": "run-sync-get-dataset-items-zen-studio-goofish-xianyu-item-comments-scraper",
                "x-openai-isConsequential": false,
                "summary": "Executes an Actor, waits for its completion, and returns Actor's dataset items in response.",
                "tags": [
                    "Run Actor"
                ],
                "requestBody": {
                    "required": true,
                    "content": {
                        "application/json": {
                            "schema": {
                                "$ref": "#/components/schemas/inputSchema"
                            }
                        }
                    }
                },
                "parameters": [
                    {
                        "name": "token",
                        "in": "query",
                        "required": true,
                        "schema": {
                            "type": "string"
                        },
                        "description": "Enter your Apify token here"
                    }
                ],
                "responses": {
                    "200": {
                        "description": "OK"
                    }
                }
            }
        },
        "/acts/zen-studio~goofish-xianyu-item-comments-scraper/runs": {
            "post": {
                "operationId": "runs-sync-zen-studio-goofish-xianyu-item-comments-scraper",
                "x-openai-isConsequential": false,
                "summary": "Executes an Actor and returns information about the initiated run in response.",
                "tags": [
                    "Run Actor"
                ],
                "requestBody": {
                    "required": true,
                    "content": {
                        "application/json": {
                            "schema": {
                                "$ref": "#/components/schemas/inputSchema"
                            }
                        }
                    }
                },
                "parameters": [
                    {
                        "name": "token",
                        "in": "query",
                        "required": true,
                        "schema": {
                            "type": "string"
                        },
                        "description": "Enter your Apify token here"
                    }
                ],
                "responses": {
                    "200": {
                        "description": "OK",
                        "content": {
                            "application/json": {
                                "schema": {
                                    "$ref": "#/components/schemas/runsResponseSchema"
                                }
                            }
                        }
                    }
                }
            }
        },
        "/acts/zen-studio~goofish-xianyu-item-comments-scraper/run-sync": {
            "post": {
                "operationId": "run-sync-zen-studio-goofish-xianyu-item-comments-scraper",
                "x-openai-isConsequential": false,
                "summary": "Executes an Actor, waits for completion, and returns the OUTPUT from Key-value store in response.",
                "tags": [
                    "Run Actor"
                ],
                "requestBody": {
                    "required": true,
                    "content": {
                        "application/json": {
                            "schema": {
                                "$ref": "#/components/schemas/inputSchema"
                            }
                        }
                    }
                },
                "parameters": [
                    {
                        "name": "token",
                        "in": "query",
                        "required": true,
                        "schema": {
                            "type": "string"
                        },
                        "description": "Enter your Apify token here"
                    }
                ],
                "responses": {
                    "200": {
                        "description": "OK"
                    }
                }
            }
        }
    },
    "components": {
        "schemas": {
            "inputSchema": {
                "type": "object",
                "required": [
                    "startUrls"
                ],
                "properties": {
                    "startUrls": {
                        "title": "Start URLs or Item IDs",
                        "minItems": 1,
                        "maxItems": 1000,
                        "type": "array",
                        "description": "Add one item input per line.<br><br>Supported formats:<br>• <code>https://www.goofish.com/item?id=947872178004</code><br>• <code>947872178004</code><br>• Mobile share link: <code>https://m.tb.cn/h.XXXXXX?tk=YYYYYY</code> (from the app's Share button)<br><br>Up to <b>1,000 inputs per run</b>. Duplicate item IDs are skipped. Invalid inputs are returned as unbilled rows with <code>rowStatus: invalid</code>.",
                        "items": {
                            "type": "string"
                        }
                    },
                    "maxCommentsPerItem": {
                        "title": "Max comments per item",
                        "minimum": 0,
                        "maximum": 100000,
                        "type": "integer",
                        "description": "Maximum number of top-level comments to return per item. Set to <b>0</b> for all comments. Nested replies are always included and never count toward this limit.",
                        "default": 100
                    },
                    "includeReplies": {
                        "title": "Include replies",
                        "type": "boolean",
                        "description": "Include the nested reply thread under each comment (the seller's public answers and follow-ups). Replies are always free.",
                        "default": true
                    },
                    "includeQuestions": {
                        "title": "Include buyer Q&A (问大家)",
                        "type": "boolean",
                        "description": "Also capture the buyer Q&A thread into a separate <code>item-questions</code> dataset. The first page of Q&A per item is free.",
                        "default": true
                    }
                }
            },
            "runsResponseSchema": {
                "type": "object",
                "properties": {
                    "data": {
                        "type": "object",
                        "properties": {
                            "id": {
                                "type": "string"
                            },
                            "actId": {
                                "type": "string"
                            },
                            "userId": {
                                "type": "string"
                            },
                            "startedAt": {
                                "type": "string",
                                "format": "date-time",
                                "example": "2025-01-08T00:00:00.000Z"
                            },
                            "finishedAt": {
                                "type": "string",
                                "format": "date-time",
                                "example": "2025-01-08T00:00:00.000Z"
                            },
                            "status": {
                                "type": "string",
                                "example": "READY"
                            },
                            "meta": {
                                "type": "object",
                                "properties": {
                                    "origin": {
                                        "type": "string",
                                        "example": "API"
                                    },
                                    "userAgent": {
                                        "type": "string"
                                    }
                                }
                            },
                            "stats": {
                                "type": "object",
                                "properties": {
                                    "inputBodyLen": {
                                        "type": "integer",
                                        "example": 2000
                                    },
                                    "rebootCount": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "restartCount": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "resurrectCount": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "computeUnits": {
                                        "type": "integer",
                                        "example": 0
                                    }
                                }
                            },
                            "options": {
                                "type": "object",
                                "properties": {
                                    "build": {
                                        "type": "string",
                                        "example": "latest"
                                    },
                                    "timeoutSecs": {
                                        "type": "integer",
                                        "example": 300
                                    },
                                    "memoryMbytes": {
                                        "type": "integer",
                                        "example": 1024
                                    },
                                    "diskMbytes": {
                                        "type": "integer",
                                        "example": 2048
                                    }
                                }
                            },
                            "buildId": {
                                "type": "string"
                            },
                            "defaultKeyValueStoreId": {
                                "type": "string"
                            },
                            "defaultDatasetId": {
                                "type": "string"
                            },
                            "defaultRequestQueueId": {
                                "type": "string"
                            },
                            "buildNumber": {
                                "type": "string",
                                "example": "1.0.0"
                            },
                            "containerUrl": {
                                "type": "string"
                            },
                            "usage": {
                                "type": "object",
                                "properties": {
                                    "ACTOR_COMPUTE_UNITS": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "DATASET_READS": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "DATASET_WRITES": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "KEY_VALUE_STORE_READS": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "KEY_VALUE_STORE_WRITES": {
                                        "type": "integer",
                                        "example": 1
                                    },
                                    "KEY_VALUE_STORE_LISTS": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "REQUEST_QUEUE_READS": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "REQUEST_QUEUE_WRITES": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "DATA_TRANSFER_INTERNAL_GBYTES": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "DATA_TRANSFER_EXTERNAL_GBYTES": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "PROXY_RESIDENTIAL_TRANSFER_GBYTES": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "PROXY_SERPS": {
                                        "type": "integer",
                                        "example": 0
                                    }
                                }
                            },
                            "usageTotalUsd": {
                                "type": "number",
                                "example": 0.00005
                            },
                            "usageUsd": {
                                "type": "object",
                                "properties": {
                                    "ACTOR_COMPUTE_UNITS": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "DATASET_READS": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "DATASET_WRITES": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "KEY_VALUE_STORE_READS": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "KEY_VALUE_STORE_WRITES": {
                                        "type": "number",
                                        "example": 0.00005
                                    },
                                    "KEY_VALUE_STORE_LISTS": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "REQUEST_QUEUE_READS": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "REQUEST_QUEUE_WRITES": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "DATA_TRANSFER_INTERNAL_GBYTES": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "DATA_TRANSFER_EXTERNAL_GBYTES": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "PROXY_RESIDENTIAL_TRANSFER_GBYTES": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "PROXY_SERPS": {
                                        "type": "integer",
                                        "example": 0
                                    }
                                }
                            }
                        }
                    }
                }
            }
        }
    }
}
```
