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.5.dev0-cp312-cp312-manylinux_2_28_x86_64.whl (3.4 MB view details)

Uploaded CPython 3.12manylinux: glibc 2.28+ x86-64

igapi_rs-0.0.5.dev0-cp312-cp312-manylinux_2_28_aarch64.whl (3.3 MB view details)

Uploaded CPython 3.12manylinux: glibc 2.28+ ARM64

igapi_rs-0.0.5.dev0-cp312-cp312-macosx_10_13_x86_64.macosx_11_0_arm64.macosx_10_13_universal2.whl (6.1 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.5.dev0-cp312-cp312-manylinux_2_28_x86_64.whl.

File metadata

File hashes

Hashes for igapi_rs-0.0.5.dev0-cp312-cp312-manylinux_2_28_x86_64.whl
Algorithm Hash digest
SHA256 5692887560bc076fcc76086012a22f11cd61e2d09b6686898440fbe0f37ed1d1
MD5 0c8fba26ec7e5058f55066330bc4601c
BLAKE2b-256 a0e6f78c0b0ae5b17bc5cfa3a53fb5aa8c3492c63a7a7b91b2cacdbe7dea8c81

See more details on using hashes here.

Provenance

The following attestation bundles were made for igapi_rs-0.0.5.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.5.dev0-cp312-cp312-manylinux_2_28_aarch64.whl.

File metadata

File hashes

Hashes for igapi_rs-0.0.5.dev0-cp312-cp312-manylinux_2_28_aarch64.whl
Algorithm Hash digest
SHA256 995535500fcad52ddffb380299e444255ce05e4d23ef7c7bcc989332897b6fad
MD5 87f0fd86e80fda2c401e96fca6ec46cf
BLAKE2b-256 23ae77b4130a9f7eeb276440dcc844060986e4cf0e7b06e51b6f47be47a875ef

See more details on using hashes here.

Provenance

The following attestation bundles were made for igapi_rs-0.0.5.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.5.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.5.dev0-cp312-cp312-macosx_10_13_x86_64.macosx_11_0_arm64.macosx_10_13_universal2.whl
Algorithm Hash digest
SHA256 fd0e1c19163b61961a45265b29690bd2df2f7045d859a30ef29ad3dc816d0ba7
MD5 54360e8899df5897ecb1e8b8e85fd065
BLAKE2b-256 702f36ce9e9a463e450d41f820c5bea80858ae86fd15ba6cb7b6afecdb1ca926

See more details on using hashes here.

Provenance

The following attestation bundles were made for igapi_rs-0.0.5.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