Skip to main content

Alpha 法律数据查询命令行工具(案例 / 法规 / 实务文章)

Project description

alphadata-cli

Alpha 法律数据查询命令行工具。封装案例、法规、实务文章三大数据接口,提供统一的 alphadata 命令行入口。

  • 🔑 两级鉴权:API Key 持久化(环境变量 / 配置文件),Token 自动换取并缓存(内存级缓存文件,权限 600)
  • 🌳 字段表内置:按需查询字段表,避免一次性拉取撑爆上下文
  • 🧩 结构化查询:传入英文参数 + 中文值,CLI 自动查字段表拼查询字符串(支持多级层级自动判断、code 映射)
  • 🪶 零第三方依赖:纯 Python 标准库实现(urllib / argparse / json)

安装

支持两种安装方式,任选其一。

要求 Python 3.8+。

方式一:uv(推荐)

uv 会自动处理命令的 PATH 注册,不会出现「装好了但命令找不到」的问题,适合所有用户。

# 没装 uv 先装(Homebrew,一次性)
brew install uv

# 装本工具
uv tool install alphadata-cli

# 验证
alphadata --version

升级 / 卸载:

uv tool upgrade alphadata-cli   # 升级到最新版
uv tool uninstall alphadata-cli # 卸载

方式二:pip

pip install alphadata-cli

⚠️ macOS 系统 Python 常见坑:用系统自带 Python(非 Homebrew)时,pip 默认装到用户目录,可能装完后提示 command not found。解决办法二选一:

  • 推荐改用上面的 uv 方式(自动处理 PATH)
  • 或手动把用户 bin 加进 PATH:
    echo 'export PATH="$HOME/Library/Python/3.9/bin:$PATH"' >> ~/.bash_profile && source ~/.bash_profile
    
    3.9 换成你实际的 Python 版本)

安装后即获得 alphadata 命令。

快速开始

1. 配置 API Key

alphadata auth login --api-key ak_xxx

API Key 会保存到 ~/.alpha/config.json,Token 缓存到 ~/.alpha/.token(权限 600,30 天有效)。

也可通过环境变量配置:

export ALPHADATA_API_KEY=ak_xxx

2. 查询

# 法规:先查专题字段,再查
alphadata law fields --topic --search 股权
alphadata law search --topic 股权代持 --validity 现行有效

# 案例:结构化参数,CLI 自动判层级
alphadata case search --cause 民事 --court_level 最高人民法院
alphadata case search --court_view "诈骗 自首" --region 北京市

# 实务文章
alphadata article search --topic 公司法 --publish_time 近三个月

3. 详情

alphadata law detail --lid <法规ID> --title 民法典 --article 1
alphadata case detail --jid <案例ID>
alphadata article detail --aid <文章ID>

命令总览

alphadata
├── case      案例查询(search / detail / fields)
├── law       法规查询(search / detail / fields)
├── article   实务文章查询(search / detail / fields)
└── auth      鉴权管理(login / status / logout)

鉴权流程

API Key (持久化)  →  换取 Token (缓存)  →  Token 鉴权查询数据
                          ↑                       │
                          └── 过期/失效自动重换 ←──┘
  • API Key:持久存储在 ~/.alpha/config.json 和环境变量 ALPHADATA_API_KEY
  • Token:仅在本地缓存文件中,自动管理,关机/过期后自动用 API Key 重新换取

结构化查询

search 子命令支持两种查询方式:

  1. 结构化参数(推荐):英文 flag + 中文值,CLI 自动查字段表拼查询字符串

    alphadata law search --topic 股权代持 --validity 现行有效
    # CLI 自动拼成: Alpha实务专题_3:股权代持,时效性_1:现行有效
    
  2. 原始查询(兜底):直接透传,跳过字段校验

    alphadata law search --query "全文_99:民法典"
    

开发

本项目采用标准 Python 包结构(src layout):

# 本地开发安装
pip install -e .

# 构建
pip install build
python -m build

License

MIT

Project details


Download files

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

Source Distribution

alphadata_cli-0.1.0.dev11.tar.gz (197.7 kB view details)

Uploaded Source

Built Distribution

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

alphadata_cli-0.1.0.dev11-py3-none-any.whl (208.3 kB view details)

Uploaded Python 3

File details

Details for the file alphadata_cli-0.1.0.dev11.tar.gz.

File metadata

  • Download URL: alphadata_cli-0.1.0.dev11.tar.gz
  • Upload date:
  • Size: 197.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.13

File hashes

Hashes for alphadata_cli-0.1.0.dev11.tar.gz
Algorithm Hash digest
SHA256 a3cdde7c93423bffda6dd50c47ba11fddc3c3cbb30e93aa283966099a7c390da
MD5 69786db1851917b63f9094490ac19a35
BLAKE2b-256 4285d3bb81cf34844fc6b2694994fc9eddeab68df539f666d58c694051502336

See more details on using hashes here.

File details

Details for the file alphadata_cli-0.1.0.dev11-py3-none-any.whl.

File metadata

File hashes

Hashes for alphadata_cli-0.1.0.dev11-py3-none-any.whl
Algorithm Hash digest
SHA256 c952325fdfbad1a36032a62c3ada63dd290d57bc9d0b30a072b328ce9017d518
MD5 12c187b1fdf00908eddd468ac31ef357
BLAKE2b-256 25eb40189cead0a407404454614eb1ecb2bd33a3bc5aba791c9eec9634e0eaba

See more details on using hashes here.

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