Skip to main content

Python bindings for Instagram Private API

Project description

igapi-rs

PyPI Python License

Instagram 私有 API 的 Python 绑定,基于 Rust + PyO3 构建,高性能、异步优先。

支持 Android / iOS / Web 三平台模拟。

安装

pip install igapi-rs

环境要求

  • Python 3.10+

快速开始

import igapi

# 创建客户端
client = igapi.Client()

# 登录
client.login("username", "password")

# 获取用户信息
user = client.user_info(12345678)
print(f"用户: @{user.username}")
print(f"粉丝数: {user.follower_count}")

# 搜索用户
results = client.search_users("instagram")
for user in results:
    print(f"@{user.username}")

# 获取用户动态
feed = client.user_feed(12345678)
for media in feed.items:
    print(f"媒体: {media.id}, 点赞: {media.like_count}")

API 参考

Client

Client(proxy: str | None = None, platform: str = "android")

创建新的 Instagram API 客户端。

参数:

方法:

login(username: str, password: str) -> None

登录 Instagram。

异常:

  • PermissionError: 登录失败(密码错误、需要验证等)
  • ValueError: 无效的凭据
  • RuntimeError: 网络或 API 错误

is_logged_in() -> bool

检查当前是否已登录。

user_info(user_id: int) -> User

通过 ID 获取用户信息。

异常:

  • KeyError: 用户未找到
  • PermissionError: 需要登录

search_users(query: str) -> list[User]

通过用户名或名称搜索用户。

user_feed(user_id: int, max_id: str | None = None) -> Feed

获取用户的媒体动态。

参数:

  • user_id: 要获取动态的用户 ID
  • max_id (可选): 分页游标

类型定义

User

class User:
    pk: int                 # 用户 ID
    username: str           # 用户名
    full_name: str          # 全名
    is_private: bool        # 是否私密账户
    profile_pic_url: str    # 头像 URL
    follower_count: int     # 粉丝数
    following_count: int    # 关注数

Media

class Media:
    id: str                 # 媒体 ID
    media_type: int         # 类型(1=图片, 2=视频, 8=轮播)
    caption_text: str       # 描述文字
    like_count: int         # 点赞数
    comment_count: int      # 评论数

Feed

class Feed:
    items: list[Media]      # 媒体项目列表
    has_more: bool          # 是否有更多项目
    next_cursor: str | None # 下一页游标

错误处理

try:
    client.login("user", "pass")
except PermissionError as e:
    # 登录失败、需要验证、双因素认证等
    print(f"登录错误: {e}")
except ValueError as e:
    # 无效的凭据
    print(f"无效输入: {e}")
except RuntimeError as e:
    # API 或网络错误
    print(f"错误: {e}")

使用代理

# HTTP 代理
client = igapi.Client(proxy="http://localhost:8080")

# HTTPS 代理
client = igapi.Client(proxy="https://proxy.example.com:8080")

# SOCKS 代理
client = igapi.Client(proxy="socks5://localhost:1080")

示例

完整使用示例请参见 examples/python_example.py

开发

构建

# 调试构建
maturin develop

# 发布构建
maturin develop --release

# 构建 wheel 包
maturin build --release

测试

# 运行测试
python -m pytest tests/

# 类型检查
mypy --strict examples/

性能

Python 绑定使用 PyO3,保持接近原生 Rust 的性能:

  • API 调用通过 Tokio 异步处理
  • 最小化序列化开销
  • 尽可能使用零拷贝数据访问

许可证

MIT OR Apache-2.0

链接

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distributions

No source distribution files available for this release.See tutorial on generating distribution archives.

Built Distributions

If you're not sure about the file name format, learn more about wheel file names.

igapi_rs-0.0.2.dev0-cp312-cp312-manylinux_2_28_x86_64.whl (3.1 MB view details)

Uploaded CPython 3.12manylinux: glibc 2.28+ x86-64

igapi_rs-0.0.2.dev0-cp312-cp312-manylinux_2_28_aarch64.whl (2.9 MB view details)

Uploaded CPython 3.12manylinux: glibc 2.28+ ARM64

igapi_rs-0.0.2.dev0-cp312-cp312-macosx_10_13_x86_64.macosx_11_0_arm64.macosx_10_13_universal2.whl (5.4 MB view details)

Uploaded CPython 3.12macOS 10.13+ universal2 (ARM64, x86-64)macOS 10.13+ x86-64macOS 11.0+ ARM64

File details

Details for the file igapi_rs-0.0.2.dev0-cp312-cp312-manylinux_2_28_x86_64.whl.

File metadata

File hashes

Hashes for igapi_rs-0.0.2.dev0-cp312-cp312-manylinux_2_28_x86_64.whl
Algorithm Hash digest
SHA256 1cab4c5982dc661b0a64538f9ec34b9fba3eb13c4a071523fb5b12fe6da21c29
MD5 8c6d1e842a5f8e2c191c7557e2f12239
BLAKE2b-256 4ac7094f4696d56bbc14cde451a81a85d390cf58f2b22c5bea3defa6891631ac

See more details on using hashes here.

Provenance

The following attestation bundles were made for igapi_rs-0.0.2.dev0-cp312-cp312-manylinux_2_28_x86_64.whl:

Publisher: build-and-release.yml on open-luban/igapi-rs

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file igapi_rs-0.0.2.dev0-cp312-cp312-manylinux_2_28_aarch64.whl.

File metadata

File hashes

Hashes for igapi_rs-0.0.2.dev0-cp312-cp312-manylinux_2_28_aarch64.whl
Algorithm Hash digest
SHA256 4174013a94026679a099d52f81395acb1006068e8b5bac3817e857cca818a7e0
MD5 3e91b04d9019ad5d88a643b6fb6925f6
BLAKE2b-256 6a945cb1d5d0945c63c48cf64e40edd24d090f1c6c724916c7efa490f25fcb33

See more details on using hashes here.

Provenance

The following attestation bundles were made for igapi_rs-0.0.2.dev0-cp312-cp312-manylinux_2_28_aarch64.whl:

Publisher: build-and-release.yml on open-luban/igapi-rs

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file igapi_rs-0.0.2.dev0-cp312-cp312-macosx_10_13_x86_64.macosx_11_0_arm64.macosx_10_13_universal2.whl.

File metadata

File hashes

Hashes for igapi_rs-0.0.2.dev0-cp312-cp312-macosx_10_13_x86_64.macosx_11_0_arm64.macosx_10_13_universal2.whl
Algorithm Hash digest
SHA256 a299019385b5adbe86798f87f0f1d24b74987d5181769d97dc3a177e5d531e18
MD5 32249b10955c4f1ee4be886d9c7bb7d5
BLAKE2b-256 12c81cdeff9dc1b7c15c86a6a1412078e5958508402f8ebe7d4088c909d32c89

See more details on using hashes here.

Provenance

The following attestation bundles were made for igapi_rs-0.0.2.dev0-cp312-cp312-macosx_10_13_x86_64.macosx_11_0_arm64.macosx_10_13_universal2.whl:

Publisher: build-and-release.yml on open-luban/igapi-rs

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page