# Bark Reviews Scraper (`ecomscrape/bark-reviews-scraper`) Actor

The Bark.com Reviews Scraper is a robust tool that extracts detailed customer reviews from Bark.com, delivering structured data in formats like JSON by providing Business URLs.

- **URL**: https://apify.com/ecomscrape/bark-reviews-scraper.md
- **Developed by:** [ecomscrape](https://apify.com/ecomscrape) (community)
- **Categories:** Jobs, Automation, Lead generation
- **Stats:** 25 total users, 0 monthly users, 100.0% runs succeeded, 0 bookmarks
- **User rating**: No ratings yet

## Pricing

$20.00/month + usage

To use this Actor, you pay a monthly rental fee to the developer. The rent is subtracted from your prepaid usage every month after the free trial period.You also pay for the Apify platform usage, which gets cheaper the higher Apify subscription plan you have.

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

## 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

## Contact

If you encounter any issues or need to exchange information, please feel free to contact us through the following link:
[My profile](https://apify.com/ecomscrape)


## **Advanced Bark.com Customer Reviews Data Extraction Tool**

In today's competitive service marketplace landscape, customer reviews and ratings serve as crucial indicators of business performance and reputation. Bark.com is a web-based services marketplace headquartered in London that was founded in November 2014 by British entrepreneurs Andrew Michael and Kai Feller, connecting service buyers with suitable providers across over 1,500 unique categories. The platform hosts thousands of genuine customer reviews, with over 102,925 reviews collected and maintaining ratings that vary across different review platforms. For businesses, market researchers, and analysts, accessing this wealth of review data manually would be incredibly time-consuming and impractical.

### Comprehensive Review Data Extraction Solution

The Bark.com Reviews Scraper is designed to automatically extract comprehensive review and rating information from individual business profiles on the Bark platform. This powerful tool eliminates the manual effort required to collect customer feedback data, providing businesses and researchers with structured access to valuable market intelligence.

The scraper targets specific business profile pages, extracting detailed review information including customer ratings, written feedback, reviewer information, and business responses. This makes it particularly valuable for competitive analysis, reputation monitoring, service quality assessment, and market research initiatives across various service industries represented on Bark.com.

Primary users include digital marketing agencies conducting competitor research, business owners monitoring their reputation, market researchers analyzing service industry trends, and data analysts building comprehensive customer sentiment datasets.

### Detailed Input and Output Specifications

Example url 1: https://www.bark.com/en/gb/b/cigma-accounting-ltd/7VlN/

Example url 2: https://www.bark.com/en/gb/company/kii-accountants-limited/bAn3/

Example url 3: https://www.bark.com/en/gb/company/sak-accountants-limited/0BYzZ/
    
Example Screenshot of business information page:
    
![](https://i.ibb.co/JFBqpmf/Screenshot-from-2025-01-22-00-13-15.png)


#### Input Format Requirements

The scraper accepts a JSON configuration specifying target URLs and extraction parameters:
    

```json
{
  "max_retries_per_url": 2, // Maximum waiting time when accessing the links you provided.
  "proxy": { // Add a proxy to ensure that during the data collection process, you are not detected as a bot.
    "useApifyProxy": true,
    "apifyProxyGroups": [
      "RESIDENTIAL" 
    ],
    "apifyProxyCountry": "SG" // You should choose an Country that coincides with the Country you want to collect data from
  },
  "max_items_per_url": 20,
  "urls": [ // Links to business information pages.
    "https://www.bark.com/en/gb/b/cigma-accounting-ltd/7VlN/",
    "https://www.bark.com/en/gb/company/sak-accountants-limited/0BYzZ/",
    "https://www.bark.com/en/gb/company/sak-accountants-limited/0BYzZ/"
  ]
}
````

The input requires direct links to specific business profile pages on Bark.com. The `max_items_per_url` parameter controls how many reviews to extract per business, while `max_retries_per_url` handles potential connection issues. The proxy configuration ensures reliable data collection without triggering anti-bot measures, with residential proxies providing the most authentic browsing behavior.

#### Output Data Structure

You get the output from the Bark.com Reviews Scraper stored in a tab. The following is an example of the Information Fields collected after running the Actor.

```json
[ // List of reviews information
  {
    "author": "Christopher Bond",
    "date_published": "2024-11-21",
    "rating": 5.0,
    "review_platform": "TrustPilot",
    "review_txt": "At first, I was slightly reluctant to use this company as my agent for self assessment, mainly because they were very persistent with phone calls etc urging me to choose them from among several other agents I was considering. That sort of thing makes me suspicious! However, I cannot fault them on their efficiency and customer service: they responded swiftly to all my queries etc. More... That sort of thing makes me suspicious! However, I cannot fault them on their efficiency and customer service: they responded swiftly to all my queries etc.",
    "reply": [],
    "from_url": "https://www.bark.com/en/gb/b/cigma-accounting-ltd/7VlN/"
  }, // ... Many other reviews details
]
```

The scraper returns structured review data with the following fields:

- **Author**: The reviewer's name or identifier, providing attribution for each review and enabling reviewer pattern analysis
- **Date Published**: Timestamp when the review was posted, crucial for tracking review trends over time and analyzing recent vs. historical feedback
- **Rating**: Numerical score given by the reviewer, typically on a 1-5 star scale, enabling quantitative sentiment analysis and average rating calculations
- **Review Platform**: Identifies Bark.com as the source platform, important when aggregating reviews from multiple sources for comprehensive analysis
- **Review Text**: Complete written feedback from the customer, containing detailed qualitative insights about service quality, customer experience, and specific business interactions
- **Reply**: Business owner's response to the review, providing insights into customer service approach, issue resolution, and business communication style

Each field serves specific analytical purposes: Author and Date enable trend analysis, Rating provides quantitative metrics, Review Text offers qualitative insights, and Reply data reveals business responsiveness and customer service quality.

### Step-by-Step Usage Guide

1. **Prepare Target URLs**: Collect direct links to Bark.com business profile pages you want to analyze
2. **Configure Parameters**: Set appropriate values for max\_items\_per\_url based on your data needs and max\_retries\_per\_url for reliability
3. **Set Proxy Settings**: Use residential proxies matching your target geography to avoid detection
4. **Execute Extraction**: Run the scraper with your JSON configuration
5. **Process Results**: Export the structured data for analysis, reporting, or integration with other business intelligence tools

**Best Practices**: Start with smaller batches to test configuration, use country-specific proxies when analyzing regional businesses, and implement delays between requests to maintain ethical scraping practices. Monitor for changes in Bark.com's structure that might affect extraction accuracy.

Common issues include blocked requests (resolved with proper proxy configuration) and incomplete data extraction (addressed by adjusting retry parameters and ensuring URLs are correctly formatted).

### Business Applications and Benefits

This scraper provides significant time savings compared to manual review collection, transforming hours of copy-paste work into minutes of automated extraction. The structured output enables immediate integration with analytics tools, CRM systems, and business intelligence platforms.

Practical applications include competitive benchmarking by comparing review sentiment across similar service providers, reputation monitoring to track customer satisfaction trends, market research to understand customer preferences and pain points, and lead qualification by analyzing potential business partners' customer feedback history.

The extracted data supports data-driven decision making in service selection, partnership evaluation, and market positioning strategies, providing quantifiable insights that would otherwise require extensive manual research.

### Maximize Your Service Industry Intelligence

The Bark.com Reviews Scraper transforms time-consuming review research into efficient, automated data collection, providing the structured customer feedback insights essential for informed business decisions. Whether conducting competitive analysis, monitoring reputation, or researching market trends, this tool delivers comprehensive review data in a format ready for immediate analysis and application.

## Related Actors

- [**Bark.com Seller Details Page Scraper**](https://apify.com/ecomscrape/bark-seller-details-page-scraper): A specialized data extraction solution engineered to harvest detailed service provider information from Bark's extensive professional services marketplace.

## Your feedback

We are always working to improve Actors' performance. So, if you have any technical feedback about Bark.com Reviews Scraper or simply found a bug, please create an issue on the Actor's Issues tab in Apify Console.

# Actor input Schema

## `urls` (type: `array`):

Add the URLs of the Specific service urls you want to scrape. You can paste URLs one by one, or use the Bulk edit section to add a prepared list.

## `max_items_per_url` (type: `integer`):

Limit the number of items per URL you want to scrape

## `max_retries_per_url` (type: `integer`):

Limit the number of retries for each URL if the scrape is detected as a bot or the page fails to load

## `proxy` (type: `object`):

Select proxies to be used by your scraper.

## Actor input object example

```json
{
  "urls": [
    "https://www.bark.com/en/gb/b/cigma-accounting-ltd/7VlN/"
  ],
  "max_items_per_url": 20,
  "max_retries_per_url": 2,
  "proxy": {
    "useApifyProxy": false
  }
}
```

# 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 = {
    "urls": [
        "https://www.bark.com/en/gb/b/cigma-accounting-ltd/7VlN/"
    ],
    "max_items_per_url": 20,
    "max_retries_per_url": 2,
    "proxy": {
        "useApifyProxy": false
    }
};

// Run the Actor and wait for it to finish
const run = await client.actor("ecomscrape/bark-reviews-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 = {
    "urls": ["https://www.bark.com/en/gb/b/cigma-accounting-ltd/7VlN/"],
    "max_items_per_url": 20,
    "max_retries_per_url": 2,
    "proxy": { "useApifyProxy": False },
}

# Run the Actor and wait for it to finish
run = client.actor("ecomscrape/bark-reviews-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 '{
  "urls": [
    "https://www.bark.com/en/gb/b/cigma-accounting-ltd/7VlN/"
  ],
  "max_items_per_url": 20,
  "max_retries_per_url": 2,
  "proxy": {
    "useApifyProxy": false
  }
}' |
apify call ecomscrape/bark-reviews-scraper --silent --output-dataset

```

## MCP server setup

```json
{
    "mcpServers": {
        "apify": {
            "command": "npx",
            "args": [
                "mcp-remote",
                "https://mcp.apify.com/?tools=ecomscrape/bark-reviews-scraper",
                "--header",
                "Authorization: Bearer <YOUR_API_TOKEN>"
            ]
        }
    }
}

```

## OpenAPI specification

```json
{
    "openapi": "3.0.1",
    "info": {
        "title": "Bark Reviews Scraper",
        "description": "The Bark.com Reviews Scraper is a robust tool that extracts detailed customer reviews from Bark.com, delivering structured data in formats like JSON by providing Business URLs.",
        "version": "0.0",
        "x-build-id": "6cdg0Z7MBHXwqyXeI"
    },
    "servers": [
        {
            "url": "https://api.apify.com/v2"
        }
    ],
    "paths": {
        "/acts/ecomscrape~bark-reviews-scraper/run-sync-get-dataset-items": {
            "post": {
                "operationId": "run-sync-get-dataset-items-ecomscrape-bark-reviews-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/ecomscrape~bark-reviews-scraper/runs": {
            "post": {
                "operationId": "runs-sync-ecomscrape-bark-reviews-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/ecomscrape~bark-reviews-scraper/run-sync": {
            "post": {
                "operationId": "run-sync-ecomscrape-bark-reviews-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",
                "properties": {
                    "urls": {
                        "title": "URLs of the Specific service urls to scrape",
                        "type": "array",
                        "description": "Add the URLs of the Specific service urls you want to scrape. You can paste URLs one by one, or use the Bulk edit section to add a prepared list.",
                        "items": {
                            "type": "string"
                        }
                    },
                    "max_items_per_url": {
                        "title": "Limit the number of items per URL",
                        "type": "integer",
                        "description": "Limit the number of items per URL you want to scrape"
                    },
                    "max_retries_per_url": {
                        "title": "Limit the number of retries for each URL",
                        "type": "integer",
                        "description": "Limit the number of retries for each URL if the scrape is detected as a bot or the page fails to load"
                    },
                    "proxy": {
                        "title": "Proxy configuration",
                        "type": "object",
                        "description": "Select proxies to be used by your scraper."
                    }
                }
            },
            "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
                                    }
                                }
                            }
                        }
                    }
                }
            }
        }
    }
}
```
