AkShare 贡献源码

贡献指南

克隆及提交代码

  1. 请从 akshare-develop 分支 克隆,develop 分支中包含 AkShare 最新的开发代码
  2. 请提交修改后的代码到 akshare-develop 分支

代码及接口设计规范

  1. 代码需要符合 PEP 8 要求,请使用 Black 格式化代码
  2. 函数接口的设计 stock_zh_a_hist_sina 结构,其中 stock 为金融产品,zh 为国家或地区,a 为市场或品种,hist 为 history 的缩写表示历史数据,sina 表示数据源为新浪
  3. 接口函数需要增加注释,注释规则请参考 stock_zh_a_hist_sina 接口的源码
  4. 需要在接口函数的注释中增加目标网站的地址(不是具体的数接口地址,而是网页的地址)
  5. 返回数据格式要求:
    1. Pandas 中的 pandas.DataFrame 格式
    2. Pandas 中的 pandas.Series 格式
    3. Python 内置的 dict 格式

文档撰写规范

  1. 在新增或者修改接口后,需要修改相对应的接口文档,保持接口与文档的同步更新

  2. 具体的接口文档路径(以股票接口的文档为例)为:akshare->docs->data->stock->stock.md,其中 stock 表示股票文件夹,stock.md 为具体的 Markdown 文件,需要在 stock.md 中对相应的接口文档进行修改或新增

  3. 以股票分时数据接口文档为例:

    1. 主要包含以下部分内容:
      1. 接口:填写具体的接口名称
      2. 目标地址:填写具体数据获取网页的地址(不是数据接口地址)
      3. 描述:简单描述数据接口获取的数据
      4. 限量:返回数据的情况
      5. 输入参数:数据接口函数中需要输入的参数
      6. 输出参数:返回数据的字段,这里需要填写返回数据的字段和类型
      7. 接口示例:Python 调用该数据接口的代码
      8. 数据示例:利用 接口示例 代码获取的数据的接口,这里只需要复制前 5 行和后 5 行数据即刻即可。
    2. 示例如下:
    1. ##### 分时数据
    2. 接口: stock_zh_a_minute
    3. 目标地址: http://finance.sina.com.cn/realstock/company/sh600519/nc.shtml
    4. 描述: 新浪财经获取分时数据,目前可以获取 1, 5, 15, 30, 60 分钟的数据频率
    5. 限量: 单次返回指定公司的指定频率的所有历史分时行情数据
    6. 输入参数
    7. | 名称 | 类型 | 必选 | 描述|
    8. | -------- | ---- | ---- | --- |
    9. | symbol | str | Y |symbol='sh000300'; 同日频率数据接口|
    10. | period | str | Y |period='1'; 获取 1, 5, 15, 30, 60 分钟的数据频率|
    11. 输出参数
    12. | 名称 | 类型 | 默认显示 | 描述 |
    13. | ------------ | ------ | -------- | -------- |
    14. | day | datetime | Y | - |
    15. | open | float | Y | - |
    16. | high | float | Y | - |
    17. | low | float | Y | - |
    18. | close | float | Y | - |
    19. | volume | float | Y | - |
    20. | ma_price5 | float | Y | - |
    21. | ma_volume5 | float | Y | - |
    22. | ma_price10 | float | Y | - |
    23. | ma_volume10 | float | Y | - |
    24. | ma_price30 | float | Y | - |
    25. | ma_volume30 | float | Y | - |
    26. 接口示例
    27. \```python
    28. import akshare as ak
    29. stock_zh_a_minute_df = ak.stock_zh_a_minute(symbol='sz000876', period='1', adjust="qfq")
    30. print(stock_zh_a_minute_df)
    31. \

    数据示例

    ```

    1. day open high low close volume
    2. 0 2020-08-10 13:48:00 635.979995 636.343932 635.979995 636.161964 27500
    3. 1 2020-08-10 13:49:00 636.161964 636.343932 635.979995 636.343932 95400
    4. 2 2020-08-10 13:50:00 636.161964 636.889838 636.161964 636.889838 85300
    5. 3 2020-08-10 13:51:00 636.889838 637.071806 636.343932 636.889838 29800
    6. 4 2020-08-10 13:52:00 637.071806 637.617712 636.343932 637.617712 63400
    7. ... ... ... ... ... ... ...
    8. 1018 2020-08-14 14:54:00 636.343932 636.707869 635.798027 636.161964 137900
    9. 1019 2020-08-14 14:55:00 636.161964 636.161964 635.070153 635.434090 94100
    10. 1020 2020-08-14 14:56:00 635.434090 635.798027 634.706216 635.070153 161062
    11. 1021 2020-08-14 14:57:00 635.252121 635.434090 634.888184 635.252121 206572
    12. 1022 2020-08-14 15:00:00 636.161964 636.161964 636.161964 636.161964 261224

    ``` ```

声明

  1. 所提交的代码如不符合上述规范,则可能会被拒绝合并;
  2. 由于某些原因,您所提交的代码、数据接口和文档会被修改、删除或被第三方使用。