$ pip install kinopoisk-api-unofficial-client
Для получения токена необходима регистрация на сайте kinopoiskapiunofficial.tech. После регистрации перейдите в настройки своего профиля и сохраните токен.
Набор методов для работы с данными о фильмах
Возвращает базовые данные о фильме. Поле last_sync показывает дату последнего обновления данных.
Эндпоинт
: /api/v2.2/films/{id}Метод
: send_film_request(request: FilmRequest) -> FilmResponse
from kinopoisk_unofficial.kinopoisk_api_client import KinopoiskApiClient
from kinopoisk_unofficial.request.films.film_request import FilmRequest
api_client = KinopoiskApiClient("<your_token>")
request = FilmRequest(507)
response = api_client.films.send_film_request(request)
Возвращает данные о сезонах для сериала.
Эндпоинт
: /api/v2.2/films/{id}/seasonsМетод
: send_seasons_request(request: SeasonsRequest) -> SeasonsResponse
from kinopoisk_unofficial.kinopoisk_api_client import KinopoiskApiClient
from kinopoisk_unofficial.request.films.seasons_request import SeasonsRequest
api_client = KinopoiskApiClient("<your_token>")
request = SeasonsRequest(685246)
response = api_client.films.send_seasons_request(request)
Возвращает список фактов и ошибок в фильме.
Эндпоинт
: /api/v2.2/films/{id}/factsМетод
: send_facts_request(request: FactsRequest) -> FactsResponse
from kinopoisk_unofficial.kinopoisk_api_client import KinopoiskApiClient
from kinopoisk_unofficial.request.films.facts_request import FactsRequest
api_client = KinopoiskApiClient("<your_token>")
request = FactsRequest(685246)
response = api_client.films.send_facts_request(request)
Возвращает данные о прокате в разных странах.
Эндпоинт
: /api/v2.2/films/{id}/distributionsМетод
: send_distributions_request(request: DistributionsRequest) -> DistributionsResponse
from kinopoisk_unofficial.kinopoisk_api_client import KinopoiskApiClient
from kinopoisk_unofficial.request.films.distributions_request import DistributionsRequest
api_client = KinopoiskApiClient("<your_token>")
request = DistributionsRequest(507)
response = api_client.films.send_distributions_request(request)
Возвращает данные о бюджете и сборах.
Эндпоинт
: /api/v2.2/films/{id}/box_officeМетод
: send_box_office_request(request: BoxOfficeRequest) -> BoxOfficeResponse
from kinopoisk_unofficial.kinopoisk_api_client import KinopoiskApiClient
from kinopoisk_unofficial.request.films.box_office_request import BoxOfficeRequest
api_client = KinopoiskApiClient("<your_token>")
request = BoxOfficeRequest(507)
response = api_client.films.send_box_office_request(request)
Возвращает кадры из фильма.
Эндпоинт
: /api/v2.1/films/{id}/framesМетод
: send_film_frame_request(request: FilmFrameRequest) -> FilmFrameResponse
from kinopoisk_unofficial.kinopoisk_api_client import KinopoiskApiClient
from kinopoisk_unofficial.request.films.film_frame_request import FilmFrameRequest
api_client = KinopoiskApiClient("<your_token>")
request = FilmFrameRequest(507)
response = api_client.films.send_film_frame_request(request)
Получить изображения(кадры, постеры, фан-арты, обои и т.д.) связанные с фильмом по kinopoisk film id
Данный эндпоинт возвращает изображения связанные с фильмом с пагинацией. Каждая страница содержит не более чем 20 фильмов. Доступные изображения:
ImageType
- STILL - кадры
- SHOOTING - изображения со съемок
- POSTER - постеры
- FAN_ART - фан-арты
- PROMO - промо
- CONCEPT - концепт-арты
- WALLPAPER - обои
- COVER - обложки
- SCREENSHOT - скриншоты
Эндпоинт
: /api/v2.2/films/{id}/imagesМетод
: send_image_request(self, request: ImageRequest) -> ImageResponse
from kinopoisk_unofficial.kinopoisk_api_client import KinopoiskApiClient
from kinopoisk_unofficial.request.films.image_request import ImageRequest
api_client = KinopoiskApiClient("<your_token>")
request = ImageRequest(507)
response = api_client.films.send_image_request(request)
Возвращает трейлеры, тизеры, видео для фильма по kinopoisk film id.
Эндпоинт
: /api/v2.2/films/{id}/videosМетод
: send_film_video_request(request: FilmVideoRequest) -> FilmVideoResponse
from kinopoisk_unofficial.kinopoisk_api_client import KinopoiskApiClient
from kinopoisk_unofficial.request.films.film_video_request import FilmVideoRequest
api_client = KinopoiskApiClient("<your_token>")
request = FilmVideoRequest(507)
response = api_client.films.send_film_video_request(request)
Возвращает информацию о сиквелах и приквелах для фильма по kinopoisk film id.
Эндпоинт
: /api/v2.1/films/{id}/sequels_and_prequelsМетод
: send_film_sequels_and_prequels_request(request: FilmSequelsAndPrequelsRequest) -> FilmSequelsAndPrequelsResponse
from kinopoisk_unofficial.kinopoisk_api_client import KinopoiskApiClient
from kinopoisk_unofficial.request.films.film_sequels_and_prequels_request import FilmSequelsAndPrequelsRequest
api_client = KinopoiskApiClient("<your_token>")
request = FilmSequelsAndPrequelsRequest(507)
response = api_client.films.send_film_sequels_and_prequels_request(request)
Эндпоинт
: /api/v2.1/films/search-by-keywordМетод
: send_search_by_keyword_request(request: SearchByKeywordRequest) -> SearchByKeywordResponse
from kinopoisk_unofficial.kinopoisk_api_client import KinopoiskApiClient
from kinopoisk_unofficial.request.films.search_by_keyword_request import SearchByKeywordRequest
api_client = KinopoiskApiClient("<your_token>")
request = SearchByKeywordRequest("Рик и Морти")
response = api_client.films.send_search_by_keyword_request(request)
Возвращает список id стран и жанров, которые могут быть использованы в поиске по фильтру.
Эндпоинт
: /api/v2.1/films/filtersМетод
: send_filters_request(request: FiltersRequest) -> FiltersResponse
from kinopoisk_unofficial.kinopoisk_api_client import KinopoiskApiClient
from kinopoisk_unofficial.request.films.filters_request import FiltersRequest
api_client = KinopoiskApiClient("<your_token>")
request = FiltersRequest()
response = api_client.films.send_filters_request(request)
Возвращает список фильмов с пагинацией. Каждая страница содержит не более чем 20 фильмов. Используй FiltersRequest
чтобы получить id стран и жанров.
Эндпоинт
: /api/v2.1/films/search-by-filtersМетод
: send_film_search_by_filters_request(request: FilmSearchByFiltersRequest) -> FilmSearchByFiltersResponse
from kinopoisk_unofficial.kinopoisk_api_client import KinopoiskApiClient
from kinopoisk_unofficial.model.filter_country import FilterCountry
from kinopoisk_unofficial.model.filter_order import FilterOrder
from kinopoisk_unofficial.request.films.film_search_by_filters_request import FilmSearchByFiltersRequest
api_client = KinopoiskApiClient("<your_token>")
request = FilmSearchByFiltersRequest()
request.year_from = 2021
request.rating_from = 5
request.order = FilterOrder.RATING
request.add_country(FilterCountry(1, 'США'))
response = api_client.films.send_film_search_by_filters_request(request)
Возвращает список фильмов с пагинацией. Каждая страница содержит не более чем 20 фильмов. Например: https://www.kinopoisk.ru/top/lists/58/.
Эндпоинт
: /api/v2.2/films/topМетод
: send_film_top_request(request: FilmTopRequest) -> FilmTopResponse
from kinopoisk_unofficial.kinopoisk_api_client import KinopoiskApiClient
from kinopoisk_unofficial.request.films.film_top_request import FilmTopRequest
from kinopoisk_unofficial.model.dictonary.top_type import TopType
api_client = KinopoiskApiClient("<your_token>")
request = FilmTopRequest(TopType.TOP_250_BEST_FILMS)
response = api_client.films.send_film_top_request(request)
Возвращает список похожих фильмов по kinopoisk film id
Эндпоинт
: /api/v2.2/films/{id}/similarsМетод
: send_related_film_request(request: RelatedFilmRequest) -> RelatedFilmResponse
from kinopoisk_unofficial.kinopoisk_api_client import KinopoiskApiClient
from kinopoisk_unofficial.request.films.related_film_request import RelatedFilmRequest
api_client = KinopoiskApiClient("<your_token>")
request = RelatedFilmRequest(507)
response = api_client.films.send_related_film_request(request)
Возвращает список цифровых релизов. Например: https://www.kinopoisk.ru/comingsoon/digital/
Эндпоинт
: /api/v2.1/films/releasesМетод
: send_digital_release_request(request: DigitalReleaseRequest) -> DigitalReleaseResponse
from kinopoisk_unofficial.kinopoisk_api_client import KinopoiskApiClient
from kinopoisk_unofficial.request.films.digital_release_request import DigitalReleaseRequest
from kinopoisk_unofficial.model.dictonary.month import Month
api_client = KinopoiskApiClient("<your_token>")
request = DigitalReleaseRequest(2021, Month.SEPTEMBER)
response = api_client.films.send_digital_release_request(request)
Возвращает список кинопремьер. Например: https://www.kinopoisk.ru/premiere/
Эндпоинт
: /api/v2.2/films/premieresМетод
: send_premiere_request(request: PremiereRequest) -> PremiereResponse
from kinopoisk_unofficial.kinopoisk_api_client import KinopoiskApiClient
from kinopoisk_unofficial.model.dictonary.month import Month
from kinopoisk_unofficial.request.films.premiere_request import PremiereRequest
api_client = KinopoiskApiClient('<your_token>')
request = PremiereRequest(2021, Month.DECEMBER)
response = api_client.films.send_premiere_request(request)
Набор методов для работы с ревью о фильмах
Возвращает список рецензий с пагинацией. Каждая страница содержит не более чем 20 рецензий. Поле description содержит не
полный текст рецензии. Полный текст может быть получен из ReviewDetailsRequest
Эндпоинт
: /api/v1/reviewsМетод
: send_reviews_request(request: ReviewsRequest) -> ReviewsResponse
from kinopoisk_unofficial.kinopoisk_api_client import KinopoiskApiClient
from kinopoisk_unofficial.request.reviews.reviews_request import ReviewsRequest
api_client = KinopoiskApiClient("<your_token>")
request = ReviewsRequest(507)
response = api_client.reviews.send_reviews_request(request)
Возвращает полную информацию о рецензии.
Эндпоинт
: /api/v1/reviews/detailsМетод
: send_review_details_request(request: ReviewDetailsRequest) -> ReviewDetailsResponse
from kinopoisk_unofficial.kinopoisk_api_client import KinopoiskApiClient
from kinopoisk_unofficial.request.reviews.review_details_request import ReviewDetailsRequest
api_client = KinopoiskApiClient("<your_token>")
request = ReviewDetailsRequest(3000574)
response = api_client.reviews.send_review_details_request(request)
Набор методов для работы с данными об актерах, режиссерах и т.д.
Возвращает данные об актерах, режиссерах и т.д. по kinopoisk film id
Эндпоинт
: /api/v1/staffМетод
: send_staff_request(request: StaffRequest) -> StaffResponse
from kinopoisk_unofficial.kinopoisk_api_client import KinopoiskApiClient
from kinopoisk_unofficial.request.staff.staff_request import StaffRequest
api_client = KinopoiskApiClient("<your_token>")
request = StaffRequest(507)
response = api_client.staff.send_staff_request(request)
Возвращает данные о конкретном человеке по kinopoisk person id
Эндпоинт
: /api/v1/staff/{id}Метод
: send_person_request(request: PersonRequest) -> PersonResponse
from kinopoisk_unofficial.kinopoisk_api_client import KinopoiskApiClient
from kinopoisk_unofficial.request.staff.person_request import PersonRequest
api_client = KinopoiskApiClient("<your_token>")
request = PersonRequest(27977)
response = api_client.staff.send_person_request(request)
Возвращает данные об актерах, режиссерах и т.д. по имени
Одна страница может содержать до 50 элементов в items
Эндпоинт
: /api/v1/personsМетод
: send_person_by_name_request(request: PersonByNameRequest) -> PersonByNameResponse
from kinopoisk_unofficial.kinopoisk_api_client import KinopoiskApiClient
from kinopoisk_unofficial.request.persons.person_by_name_request import PersonByNameRequest
api_client = KinopoiskApiClient("<your_token>")
request = PersonByNameRequest("Джеймс Кэмерон")
response = api_client.persons.send_person_by_name_request(request)