# OK.RU Video Scraper 🎥 (`easyapi/ok-ru-video-scraper`) Actor

Scrape video search results from OK.RU (Odnoklassniki) including video details, views, likes, and metadata. Perfect for video content analysis, market research, and monitoring trending content on Russia's popular social network.

- **URL**: https://apify.com/easyapi/ok-ru-video-scraper.md
- **Developed by:** [EasyApi](https://apify.com/easyapi) (community)
- **Categories:** Social media, Videos, Integrations
- **Stats:** 35 total users, 4 monthly users, 100.0% runs succeeded, 2 bookmarks
- **User rating**: 5.00 out of 5 stars

## Pricing

from $2.99 / 1,000 results

This Actor is paid per event and usage. You are charged both the fixed price for specific events and for Apify platform usage.

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

## OK.RU Video Scraper 🎥

Extract video search results from OK.RU (Odnoklassniki), Russia's popular social network platform. This actor helps you gather comprehensive video data based on your search keywords.

### Features ✨

- 🔍 Search videos using custom keywords
- 📊 Get detailed video statistics (views, likes, duration)
- 🎯 Control maximum number of results per search
- ⚡ Fast and efficient data collection
- 🤖 Built-in anti-detection mechanisms
- 📅 Timestamp data for tracking purposes

### Output Data 📦

For each video, you'll get:
- Video title and URL
- Thumbnail images (small & large)
- View count and likes
- Video duration
- Creation date
- Owner information
- Platform-specific metadata

### Use Cases 💡

- Content Research: Analyze trending videos and topics
- Marketing Analysis: Track video performance metrics
- Competitor Monitoring: Keep track of specific content creators
- Data Collection: Gather video content for analysis
- Market Research: Understand content trends in Russian-speaking markets

### Input Parameters 🎛️

| Field | Type | Description |
|-------|------|-------------|
| keywords | Array | List of search terms to find videos |
| maxItems | Integer | Maximum number of results to collect (default: 50) |

### Limitations ⚠️

- Respects OK.RU's terms of service and rate limits
- Some videos might be region-restricted
- Results depend on OK.RU's search algorithm

### Tips 💡

- Use specific keywords for better results
- Adjust maxItems based on your needs
- Consider running the actor at regular intervals for trend analysis

Need help or have questions? Feel free to reach out through Apify's platform!


#### Input Example
  
A full explanation of an input example in JSON.  
```json
{
    "keywords": [
        "fashion"
    ],
    "maxItems": 50
}
````

#### Output sample

The results will be wrapped into a dataset which you can always find in the **Storage** tab. Here's an excerpt from the data you'd get if you apply the input parameters above:

And here is the same data but in JSON. You can choose in which format to download your data: JSON, JSONL, Excel spreadsheet, HTML table, CSV, or XML.

```json
[
    {
        "keyword": "fashion",
        "video": {
            "name": "Fashion Week Plus Size 2017 ( THE CLOTHING) Fashion Week And Lingeri ...",
            "imageUrl": "https://i.okcdn.ru/videoPreview?id=250725270864&type=47&idx=30&tkn=6fx6zyf5OcOlvIKbfFhXevD53fA&i=1&fn=external_7",
            "openMovieLink": "https://ok.ru/video/250725270864?st._aid=VideoState_open_search",
            "movie": {
                "href": "https://ok.ru/video/250725270864",
                "id": "250725270864",
                "provider": "YoutubeUser",
                "title": "Fashion Week Plus Size 2017 ( THE CLOTHING) Fashion Week And Lingerie For Curvy -the newest fashion",
                "thumbnail": {
                    "small": "https://i.okcdn.ru/videoPreview?id=250725270864&type=47&idx=30&tkn=6fx6zyf5OcOlvIKbfFhXevD53fA&i=1&fn=external_10",
                    "big": "https://i.okcdn.ru/videoPreview?id=250725270864&type=47&idx=30&tkn=6fx6zyf5OcOlvIKbfFhXevD53fA&i=1&fn=external_8"
                },
                "blocked": false,
                "duration": 547179,
                "createdMs": "1486919776579",
                "likesCount": 13,
                "totalViews": 2747,
                "dailyViews": 0,
                "height": 0,
                "width": 0
            },
            "loading": false,
            "wait": false,
            "warning": false,
            "viewsCount": 2747,
            "created": "0",
            "innerVideoContent": "<div class=\"ugrid_i js-seen-item-movie h-mod\"><div class=\"video-card js-movie-card null\"><div id=\"video-card_img_250725270864C\" class=\"video-card_img-w\"><a onclick=\"OK.VideoPlayer.openMovie(&quot;250725270864&quot;,&quot;VideoState_open_search&quot;,null,null,null,&quot;anonymMain&quot;,false,null); return false;\" aria-label=\"View\" tabindex=\"-1\" href=\"/video/250725270864?st._aid=VideoState_open_search\" class=\"video-card_lk\"><img onerror=\"OK.VVImageError(this);\" src=\"https://i.okcdn.ru/videoPreview?id=250725270864&amp;type=47&amp;idx=30&amp;tkn=6fx6zyf5OcOlvIKbfFhXevD53fA&amp;i=1&amp;fn=external_7\" alt=\"Fashion Week Plus Size 2017 ( THE CLOTHING) Fashion Week And Lingeri ...\" loading=\"lazy\" class=\"video-card_img\"><div role=\"img\" class=\"video-card_play\"></div><div data-loop=\"true\" data-poster-src=\"https://i.okcdn.ru/videoPreview?id=250725270864&amp;type=47&amp;idx=30&amp;tkn=6fx6zyf5OcOlvIKbfFhXevD53fA&amp;i=1&amp;fn=external_7\" data-hover-timeout=\"300\" data-movie-id=\"250725270864\" class=\"h-mod video-card_preview\" data-module=\"VideoPreviewAutoplay\" data-container-id=\"2352878631\"></div></a><div class=\"video-card_duration-w\"><div class=\"video-card_duration\">09:07</div></div></div><div class=\"video-card_menu\"><div class=\"video-card_menu-ac\"><svg class=\"svg-ic svg-ico_more_16\" viewBox=\"0 0 16 16\">\n<path fill-rule=\"evenodd\" clip-rule=\"evenodd\" d=\"M3.00508 6.55469c.8013 0 1.4519.65 1.4519 1.452 0 .801-.6506 1.452-1.4519 1.452-.8014 0-1.4521-.651-1.4521-1.452 0-.802.6507-1.452 1.4521-1.452zm5.0059 0c.802 0 1.452.65 1.452 1.452 0 .801-.65 1.452-1.452 1.452-.801 0-1.452-.651-1.452-1.452 0-.802.651-1.452 1.452-1.452zm5.00102 0c.801 0 1.452.65 1.452 1.452 0 .801-.651 1.452-1.452 1.452-.802 0-1.452-.651-1.452-1.452 0-.802.65-1.452 1.452-1.452z\" class=\"svg-fill\"/>\n</svg></div><div data-nocache=\"1\" data-direction=\"bottom\" data-position=\"left\" data-onClick=\"1\" data-postRequest=\"1\" data-blockid=\"VideoCardMenu_250725270864\" class=\"h-mod sc-menu_w \" data-module=\"ShortcutMenu\" data-url=\"/dk?cmd=VideoCardMenu&amp;st.vc.searchLog=on&amp;st.vc.toast=on&amp;st.vc.alp=on&amp;st.vc.dislike=on&amp;st.vc.query=fashion&amp;st.vc.movieId=250725270864&amp;st.vc.watchLater=on&amp;st.vc.qid=53085a0c6e1e3739a2ec87d90e4a0307\"></div></div><div class=\"video-card_skip-info\"><div class=\"video-card_skip-info-tx\">We will not recommend content of this kind to you anymore.</div><a data-post=\"gwt.scrl=false\" href=\"/dk?cmd=VideoCardMenu&amp;st.vc.action=RESTORE&amp;st.vc.movieId=250725270864&amp;st.cmd=anonymMain\" class=\"video-card_skip-info-action button-pro __sec __small js-restore-skipped\">Cancel</a></div></div></div>"
        },
        "scrapedAt": "2025-02-09T08:39:35.224Z"
    },
    ...
]
```

### Related Actors

- 🎥 [All-in-One Media Downloader](https://apify.com/easyapi/all-in-one-media-downloader) - Download videos, images, or audio from various platforms including TikTok, Instagram, YouTube, Facebook, Reddit, and more.
- 🎥 [VK Video Downloader](https://apify.com/easyapi/vk-video-downloader) - Download high-quality videos from VK.com and VKVideo.ru with multiple quality options.
- 📹 [Bilibili Video Downloader](https://apify.com/easyapi/bilibili-video-downloader) - Extract and download videos from Bilibili with multiple quality options.
- 🎥 [TikTok Video Downloader](https://apify.com/easyapi/tiktok-video-downloader) - Download TikTok videos without watermarks in original quality.
- 🎥 [YouTube Video and MP3 Downloader](https://apify.com/easyapi/youtube-video-and-mp3-downloader) - Download high-quality videos and audio from YouTube with batch processing capability.
- 🎥 [DailyMotion Video Downloader](https://apify.com/easyapi/dailymotion-video-downloader) - Extract video metadata and download links from DailyMotion videos in various formats.
- 🎥 [Vimeo Video Downloader](https://apify.com/easyapi/vimeo-video-downloader) - Download Vimeo videos in multiple quality options from 240p to 1080p.
- 🎥 [Facebook Video Download](https://apify.com/easyapi/facebook-video-download) - Download high-quality videos from Facebook in various resolutions.
- 🎥 [Streamable Video Downloader](https://apify.com/easyapi/streamable-video-downloader) - Extract and download videos from Streamable.com with high quality.
- 🎥 [TED Talk Video Downloader](https://apify.com/easyapi/ted-talk-video-downloader) - Download TED talk videos and audio in multiple quality options.
- 🎥 [Douyin Video Downloader](https://apify.com/easyapi/douyin-video-downloader) - Extract and download videos from Douyin without watermark.
- 🎥 [ESPN Video Downloader](https://apify.com/easyapi/espn-video-downloader) - Download ESPN videos with multiple quality options and metadata.
- 🎥 [Snapchat Video Downloader](https://apify.com/easyapi/snapchat-video-downloader) - Download videos from Snapchat stories and posts with high quality.
- 🎥 [Reddit Media Downloader](https://apify.com/easyapi/reddit-media-downloader) - Download high-quality videos, GIFs, and images from Reddit posts.
- 🎥 [Instagram Videos Downloader](https://apify.com/easyapi/instagram-videos-downloader) - Download videos from Instagram posts, reels, and stories in batch.

# Actor input Schema

## `keywords` (type: `array`):

List of keywords to search for videos

## `maxItems` (type: `integer`):

Maximum number of video results to collect per keyword

## Actor input object example

```json
{
  "keywords": [
    "fashion"
  ],
  "maxItems": 10
}
```

# 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 = {
    "keywords": [
        "fashion"
    ],
    "maxItems": 10
};

// Run the Actor and wait for it to finish
const run = await client.actor("easyapi/ok-ru-video-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 = {
    "keywords": ["fashion"],
    "maxItems": 10,
}

# Run the Actor and wait for it to finish
run = client.actor("easyapi/ok-ru-video-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 '{
  "keywords": [
    "fashion"
  ],
  "maxItems": 10
}' |
apify call easyapi/ok-ru-video-scraper --silent --output-dataset

```

## MCP server setup

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

```

## OpenAPI specification

```json
{
    "openapi": "3.0.1",
    "info": {
        "title": "OK.RU Video Scraper 🎥",
        "description": "Scrape video search results from OK.RU (Odnoklassniki) including video details, views, likes, and metadata. Perfect for video content analysis, market research, and monitoring trending content on Russia's popular social network.",
        "version": "0.0",
        "x-build-id": "YGPtrXvWb5fwe43qH"
    },
    "servers": [
        {
            "url": "https://api.apify.com/v2"
        }
    ],
    "paths": {
        "/acts/easyapi~ok-ru-video-scraper/run-sync-get-dataset-items": {
            "post": {
                "operationId": "run-sync-get-dataset-items-easyapi-ok-ru-video-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/easyapi~ok-ru-video-scraper/runs": {
            "post": {
                "operationId": "runs-sync-easyapi-ok-ru-video-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/easyapi~ok-ru-video-scraper/run-sync": {
            "post": {
                "operationId": "run-sync-easyapi-ok-ru-video-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": [
                    "keywords"
                ],
                "properties": {
                    "keywords": {
                        "title": "Search Keywords",
                        "uniqueItems": true,
                        "type": "array",
                        "description": "List of keywords to search for videos",
                        "default": [
                            "fashion"
                        ],
                        "items": {
                            "type": "string"
                        }
                    },
                    "maxItems": {
                        "title": "Maximum Results",
                        "minimum": 10,
                        "maximum": 10000,
                        "type": "integer",
                        "description": "Maximum number of video results to collect per keyword",
                        "default": 50
                    }
                }
            },
            "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
                                    }
                                }
                            }
                        }
                    }
                }
            }
        }
    }
}
```
