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.dev9.tar.gz (196.3 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.dev9-py3-none-any.whl (206.8 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: alphadata_cli-0.1.0.dev9.tar.gz
  • Upload date:
  • Size: 196.3 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.dev9.tar.gz
Algorithm Hash digest
SHA256 27a598562869771a5ecec3b637b7df46430cd5bea9b5f34452d4c57e942c7fcb
MD5 2f828efb457b4dfb6bd371b875f7eeac
BLAKE2b-256 84d79dd9c4e361d255e5720f41ea11cfc8f87a95e3f4970ceb39c16541c67521

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for alphadata_cli-0.1.0.dev9-py3-none-any.whl
Algorithm Hash digest
SHA256 3fbe82c4ae519839a167e0bbf7fb946fa9d4dc3c244d2e0aef83f005ec32b1b8
MD5 aea72277eb3126c035e80e4033463e95
BLAKE2b-256 b952ba6eef47ee994895da39b157feda373cefe9dd047dc77db7144af593f4d1

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