# Tasty Search (`pintostudio/tasty-search`) Actor

This Apify actor scrapes recipe data from Tasty.co, one of the world's largest food-focused digital platforms. It enables developers, food enthusiasts, and researchers to programmatically access Tasty's extensive recipe database through a simple API interface.

- **URL**: https://apify.com/pintostudio/tasty-search.md
- **Developed by:** [Pinto Studio](https://apify.com/pintostudio) (community)
- **Categories:** Automation, Travel
- **Stats:** 4 total users, 0 monthly users, 100.0% runs succeeded, 0 bookmarks
- **User rating**: No ratings yet

## Pricing

$27.99/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

## Tasty Recipes Search Actor Documentation

### Overview
This Apify actor scrapes recipe data from Tasty.co, one of the world's largest food-focused digital platforms. It enables developers, food enthusiasts, and researchers to programmatically access Tasty's extensive recipe database through a simple API interface.

### Features
- Search through thousands of Tasty.co recipes
- Retrieve detailed recipe information including ingredients, instructions, and nutritional data
- Support for pagination to handle large result sets
- Easy integration with other applications and workflows
- Efficient data extraction with rate limiting and error handling

### Input Parameters

| Parameter | Type | Default | Description |
|-----------|------|---------|-------------|
| `query` | string | "chicken" | Search keyword for recipes (e.g., "pasta", "vegetarian", "dessert") |
| `page` | string | "1" | Page number for pagination through search results |
| `perPage` | string | "20" | Number of results to return per page (max: 100) |

### Usage Examples

#### Basic Usage
```javascript
const input = {
    "query": "pasta",
    "page": "1",
    "perPage": "20"
};
````

#### Advanced Search

```javascript
const input = {
    "query": "vegetarian curry",
    "page": "2",
    "perPage": "50"
};
```

### Output Format

The actor returns data in JSON format with the following structure:

```json
{
    "results": [
        {
            "id": "recipe_id",
            "name": "Recipe Name",
            "description": "Recipe Description",
            "ingredients": [...],
            "instructions": [...],
            "nutritionalInfo": {...},
            "cookTime": "...",
            "servings": "..."
        }
    ],
    "totalCount": 100,
    "currentPage": 1
}
```

### Use Cases

- Recipe aggregation websites and apps
- Meal planning services
- Food bloggers and content creators
- Nutritional analysis tools
- Restaurant menu inspiration
- Dietary requirement filtering

### Installation & Setup

1. Create an Apify account at [apify.com](https://apify.com)
2. Navigate to the Apify Console
3. Search for "Tasty Recipes Search Actor"
4. Click "Try Actor"

### Running the Actor

#### Via Apify Console

1. Open the actor in Apify Console
2. Configure input parameters
3. Click "Run"

#### Via API

```bash
curl --request POST \
  --url https://api.apify.com/v2/acts/[ACTOR_NAME]/runs?token=[YOUR_API_TOKEN] \
  --header 'content-type: application/json' \
  --data '{
    "query": "chicken",
    "page": "1",
    "perPage": "20"
  }'
```

### Best Practices

- Use specific search terms for better results
- Implement pagination for large data sets
- Consider rate limiting for bulk requests
- Cache results when appropriate
- Handle error responses gracefully

### Error Handling

The actor implements robust error handling for common scenarios:

- Invalid input parameters
- Network connectivity issues
- Rate limiting responses
- Invalid or empty search results

### Limitations

- Maximum 100 results per page
- Rate limiting applies to prevent server overload
- Some premium recipes might not be accessible
- Search results depend on Tasty.co's content availability

### Support

Contact support at pintoflowpt@gmail.com

### Keywords

recipes, tasty, food scraping, recipe api, cooking, meal planning, food data, web scraping, apify actor, tasty.co, recipe search, food database, cooking api, recipe crawler, food scraper

### Related Projects

- https://apify.com/pintostudio/tasty-meals

### Tasty.co Enthusiast 🍳

Passionate about exploring the culinary world through Tasty's innovative recipes and cooking videos. I love their bite-sized recipe formats and creative food hacks that make cooking accessible and fun.

#### What I Love About Tasty

- Their signature overhead cooking videos that revolutionized food content
- The diverse range of recipes spanning global cuisines
- Their handy meal prep guides and kitchen organization tips
- The vibrant community of home cooks sharing their Tasty-inspired creations

#### Favorite Tasty Series

- Tasty 101 - Essential cooking techniques and kitchen basics
- Behind the Recipe - Deep dives into classic dishes
- Make It Fancy - Elevating everyday recipes
- Budget Eats - Creative cooking on a budget
- Tasty After Dark - Late-night comfort food creations

#### Kitchen Equipment I Use

Inspired by Tasty's recommendations:

- Non-stick pan set for perfect one-pan meals
- Stand mixer for those viral baking recipes
- Food processor for quick prep work
- Digital kitchen scale for precise measurements
- Instant-read thermometer for foolproof cooking

#### Recipe Testing Journey

Following my adventure through Tasty's most popular recipes:

- Mastering their famous mac and cheese variations
- Perfecting the art of their one-pot pasta dishes
- Experimenting with viral dessert trends
- Creating meal prep solutions for busy weeks

#### Frequently Asked Questions

**Q: What makes Tasty different from other recipe platforms?**
A: Tasty pioneered the overhead cooking video format and specializes in approachable, visually appealing recipes with clear instructions. Their content combines entertainment with practical cooking education.

**Q: Are Tasty recipes suitable for beginners?**
A: Yes! Tasty offers recipes for all skill levels, with detailed video tutorials and step-by-step instructions. Their Tasty 101 series is especially helpful for kitchen novices.

**Q: Do I need special equipment for Tasty recipes?**
A: While some recipes benefit from specific tools, most Tasty recipes can be made with basic kitchen equipment. They often provide alternative methods for those without specialized gear.

**Q: Where can I find Tasty recipes?**
A: Tasty recipes are available on their website (tasty.co), mobile app, YouTube channel, and social media platforms. The app includes helpful features like recipe saving and meal planning.

**Q: How accurate are the recipe timings?**
A: Recipe times are generally accurate for experienced cooks. Beginners might need extra time for prep work. I always recommend reading through the entire recipe first and preparing ingredients before starting.

#### Connect With Me

Let's share our Tasty cooking adventures! Drop me a message to:

- Exchange recipe modifications and tips
- Share success stories and lessons learned
- Discuss upcoming Tasty trends
- Plan virtual cooking sessions

Follow along as I recreate Tasty's viral recipes and share my own kitchen adventures! Let's make something delicious together. 🥘

\#TastyRecipes #FoodieLife #CookingJourney #TastyCommunity

# Actor input Schema

## `query` (type: `string`):

The query to search for.

## `page` (type: `string`):

The requested page number.

## `perPage` (type: `string`):

The limit per page.

## Actor input object example

```json
{
  "query": "chicken",
  "page": "1",
  "perPage": "22"
}
```

# 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 = {
    "query": "chicken",
    "page": "1",
    "perPage": "22"
};

// Run the Actor and wait for it to finish
const run = await client.actor("pintostudio/tasty-search").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 = {
    "query": "chicken",
    "page": "1",
    "perPage": "22",
}

# Run the Actor and wait for it to finish
run = client.actor("pintostudio/tasty-search").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 '{
  "query": "chicken",
  "page": "1",
  "perPage": "22"
}' |
apify call pintostudio/tasty-search --silent --output-dataset

```

## MCP server setup

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

```

## OpenAPI specification

```json
{
    "openapi": "3.0.1",
    "info": {
        "title": "Tasty Search",
        "description": "This Apify actor scrapes recipe data from Tasty.co, one of the world's largest food-focused digital platforms. It enables developers, food enthusiasts, and researchers to programmatically access Tasty's extensive recipe database through a simple API interface.",
        "version": "1.0",
        "x-build-id": "5WlcHoWnGOb9GZzZB"
    },
    "servers": [
        {
            "url": "https://api.apify.com/v2"
        }
    ],
    "paths": {
        "/acts/pintostudio~tasty-search/run-sync-get-dataset-items": {
            "post": {
                "operationId": "run-sync-get-dataset-items-pintostudio-tasty-search",
                "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/pintostudio~tasty-search/runs": {
            "post": {
                "operationId": "runs-sync-pintostudio-tasty-search",
                "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/pintostudio~tasty-search/run-sync": {
            "post": {
                "operationId": "run-sync-pintostudio-tasty-search",
                "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": [
                    "query"
                ],
                "properties": {
                    "query": {
                        "title": "query to search",
                        "type": "string",
                        "description": "The query to search for."
                    },
                    "page": {
                        "title": "page",
                        "type": "string",
                        "description": "The requested page number."
                    },
                    "perPage": {
                        "title": "perPage",
                        "type": "string",
                        "description": "The limit per page."
                    }
                }
            },
            "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
                                    }
                                }
                            }
                        }
                    }
                }
            }
        }
    }
}
```
