mirror of
https://github.com/2061360308/NeteaseCloudMusic_PythonSDK.git
synced 2024-11-21 14:38:19 +00:00
docs:更新Readme,添加.gitattributes修正项目主要语言
This commit is contained in:
parent
6b02998f4c
commit
453e9955a2
1
.gitattributes
vendored
Normal file
1
.gitattributes
vendored
Normal file
@ -0,0 +1 @@
|
|||||||
|
report.html linguist-generated
|
1
.github/workflows/publish.yml
vendored
1
.github/workflows/publish.yml
vendored
@ -19,7 +19,6 @@ jobs:
|
|||||||
with:
|
with:
|
||||||
python-version: 3.
|
python-version: 3.
|
||||||
|
|
||||||
- name: Get the version
|
|
||||||
id: get_version
|
id: get_version
|
||||||
run: |
|
run: |
|
||||||
echo "VERSION=${GITHUB_REF/refs\/tags\/v/}" >> $GITHUB_ENV
|
echo "VERSION=${GITHUB_REF/refs\/tags\/v/}" >> $GITHUB_ENV
|
||||||
|
@ -1,3 +1,10 @@
|
|||||||
|
0.1.10 (2023-12-20)
|
||||||
|
|
||||||
|
### Misc
|
||||||
|
|
||||||
|
- workflow_update
|
||||||
|
|
||||||
|
|
||||||
0.1.7 (2023-12-20)
|
0.1.7 (2023-12-20)
|
||||||
|
|
||||||
### Bugfixes
|
### Bugfixes
|
||||||
|
388
README.md
388
README.md
@ -1,23 +1,72 @@
|
|||||||
# NeteaseCloudMusic_PythonSDK
|
# NeteaseCloudMusic_PythonSDK
|
||||||
> 基于 [ NeteaseCloudMusicApi](https://github.com/Binaryify/NeteaseCloudMusicApi) 封装的 Python SDK。
|
> 基于 [NeteaseCloudMusicApi](https://github.com/Binaryify/NeteaseCloudMusicApi) 封装的 Python SDK。
|
||||||
> 网易云API Python版本。
|
> 网易云API Python版本。
|
||||||
> 现已同步原项目接口且测试通过的有200多个
|
> 现已同步原项目接口且测试通过的有200多个:wave::wave:,:star:求赞:star:
|
||||||
> 已发布到PyPi,可直接使用pip安装
|
> 已发布到PyPi,可直接使用pip安装。项目地址:[GitHub](https://github.com/2061360308/NeteaseCloudMusic_PythonSDK)
|
||||||
> 项目地址:[GitHub](https://github.com/2061360308/NeteaseCloudMusic_PythonSDK)
|
>
|
||||||
|
> 在此感谢`NeteaseCloudMusicApi`项目及其作者`Binaryify`
|
||||||
|
>
|
||||||
|
> 当然也感谢史上最最最好用的听歌软件——网易云音乐
|
||||||
|
>
|
||||||
|
> 项目仅用于学习,还望大家合理使用该项目
|
||||||
|
|
||||||
![](https://img.shields.io/badge/py_mini_racer-@0.6.0-red.svg)
|
![](https://img.shields.io/badge/py_mini_racer-@0.6.0-red.svg)
|
||||||
![License](https://img.shields.io/badge/license-MIT-yellow)
|
![License](https://img.shields.io/badge/license-MIT-yellow)
|
||||||
|
|
||||||
|
<div align="center">
|
||||||
|
<img src="./static/网易云.png" width="144" height="144" /><img src="./static/Python.jpg" width="144" height="144" /><img src="./static/Qt.jpg" width="144" height="144" /><img src="./static/idea.jpg" width="144" height="144" />
|
||||||
|
</div>
|
||||||
|
|
||||||
|
### :four_leaf_clover:项目背景
|
||||||
|
|
||||||
|
Binaryify 创建了有趣的项目[NeteaseCloudMusicApi](https://github.com/Binaryify/NeteaseCloudMusicApi)提供了较为完善的网易云接口。
|
||||||
|
|
||||||
|
但是这个项目是基于Node服务器的,对于不懂Node或是服务器搭建的小伙伴来说不易于上手,而且开发出来的项目开源后也必须依赖于Node后端服务。
|
||||||
|
|
||||||
|
这样一来这些衍生的项目在介绍时就离不开告诉使用者“如何搭建后端等等的一系列操作”,增加了项目上手的难度。他人没法快速体验一番你的作品,需要先学习后端的搭建。
|
||||||
|
|
||||||
|
事实上,我们知道,除却在网页上独有的限制,只能依赖于服务器转发,在其他平台我们完全可以不需要服务器。
|
||||||
|
|
||||||
|
所以这个Python项目诞生了。:joy::joy::joy:
|
||||||
|
|
||||||
|
### :heart:作者寄语
|
||||||
|
|
||||||
|
本项目使用Python开发,在我影响中这是一门活跃的语言,也有一群拥有许许多多“奇思妙想”的使用者。[NeteaseCloudMusicApi](https://github.com/Binaryify/NeteaseCloudMusicApi)项目开源有好多年了,得到了3万颗星,但在此之前,我发现大多都是“前端们”使用前端技术(vue,electron)进行创作,这次我把这个接口项目封装到Python平台,相信小伙伴们一定能为这个优质项目注入新的活力!
|
||||||
|
|
||||||
|
希望你们在开心创作的同时能够有不菲的收获。
|
||||||
|
|
||||||
|
<div align="center">
|
||||||
|
<img src="./static/wish.jpg" width="474" height="266" />
|
||||||
|
</div>
|
||||||
|
|
||||||
|
### :mushroom:项目用途
|
||||||
|
|
||||||
|
1. 仿网易云制作出专属于你的音乐软件
|
||||||
|
2. 赋予你的项目“音乐的力量”
|
||||||
|
3. 嗯,互联网上“下歌”,“获取歌词”,等等的炫酷操作你也能轻松实现了
|
||||||
|
4. 其他有待创新……
|
||||||
|
|
||||||
|
### :muscle:项目特点
|
||||||
|
|
||||||
|
- 完全封装于Python,不含其他知识点,不用自己处理网络请求,小白可用
|
||||||
|
- 不需要Node后端!!所有内容都封装到了库内部,可以随你的项目直接打包,其他人也可以直接下载体验,无需配置后端
|
||||||
|
- 发布到PyPI,简单使用
|
||||||
|
- 基于Python调用ECMScript,没有打包繁重的Node环境,体积小,效率高。
|
||||||
|
|
||||||
### 依赖于
|
### 依赖于
|
||||||
- [ NeteaseCloudMusicApi](https://github.com/Binaryify/NeteaseCloudMusicApi)
|
- [ NeteaseCloudMusicApi](https://github.com/Binaryify/NeteaseCloudMusicApi)
|
||||||
- [ NeteaseCloudMusicApi_V8 ](https://github.com/2061360308/NeteaseCloudMusicApi_V8)
|
- [ NeteaseCloudMusicApi_V8 ](https://github.com/2061360308/NeteaseCloudMusicApi_V8)
|
||||||
|
|
||||||
### 原理
|
### 项目原理
|
||||||
- 通过 `py_mini_racer` 调用 `NeteaseCloudMusicApi_V8` 的 `js` 方法。进一步进行了简单封装。
|
- 通过 `py_mini_racer` 调用 `NeteaseCloudMusicApi_V8` 的 `js` 方法。进一步进行了简单封装。
|
||||||
|
|
||||||
### 使用
|
<div align="center">
|
||||||
|
<img src="./static/javascript.jpg" width="474" height="266" />
|
||||||
|
</div>
|
||||||
|
|
||||||
|
### :dragon_face:使用方法
|
||||||
- 安装 `pip install NeteaseCloudMusic`
|
- 安装 `pip install NeteaseCloudMusic`
|
||||||
- 导入API进行使用(具体查看`example.py`中的示例)
|
- 导入API进行使用(具体查看[`example.py`](./example.py)中的示例)
|
||||||
```python
|
```python
|
||||||
from NeteaseCloudMusic import NeteaseCloudMusicApi, api_help, api_list
|
from NeteaseCloudMusic import NeteaseCloudMusicApi, api_help, api_list
|
||||||
import os
|
import os
|
||||||
@ -35,58 +84,300 @@ print(api_list())
|
|||||||
|
|
||||||
> 注意: request(self, name, query=None) 的第一个参数为API名称,第二个参数为API参数,具体API名称和参数请参考 [NeteaseCloudMusicApi文档](https://docs.neteasecloudmusicapi.binaryify.com),name支持`/song/url/v1`和`song_url_v1`两种写法。
|
> 注意: request(self, name, query=None) 的第一个参数为API名称,第二个参数为API参数,具体API名称和参数请参考 [NeteaseCloudMusicApi文档](https://docs.neteasecloudmusicapi.binaryify.com),name支持`/song/url/v1`和`song_url_v1`两种写法。
|
||||||
|
|
||||||
> api已加入自动缓存,在测试接口时,如果频繁调用获取结果在query里应该加上timestamp参数来区分,例如
|
> api已加入自动缓存(需要自己开启默认关闭),在测试接口时,如果频繁调用获取结果在query里应该加上timestamp参数来区分,例如
|
||||||
> ```python
|
> ```python
|
||||||
> response = netease_cloud_music_api.request("song_url_v1", {"id": 33894312, "level": "exhigh", "timestamp": time.time()})
|
> response = netease_cloud_music_api.request("song_url_v1", {"id": 33894312, "level": "exhigh", "timestamp": time.time()})
|
||||||
> ```
|
> ```
|
||||||
|
|
||||||
### 开发
|
### :eyes:开发
|
||||||
- 克隆项目 `git clone git@github.com:2061360308/NeteaseCloudMusic_PythonSDK.git`
|
如果想要参与项目开发,或是自己修改源码,请参照[开发指南](./docs/开发指南.md)。
|
||||||
- 安装依赖 `pip install -r requirements.txt`
|
|
||||||
- 目录/文件说明
|
|
||||||
```
|
|
||||||
├── package 项目包根目录
|
|
||||||
├── test_gender 生成测试代码的脚本
|
|
||||||
├── test.py 手动测试/ 使用示例
|
|
||||||
```
|
|
||||||
|
|
||||||
#### 更新
|
### 测试
|
||||||
项目使用towncrier自动生成更新日志
|
|
||||||
|
|
||||||
在 newsfragments 目录下,创建一个新的文本文件。这个文件的名字应该是一个唯一的编号,后缀是 .rst。
|
测试文件见[api_test.py](./api_test.py),测试使用了`pytest`框架
|
||||||
例如,如果你正在处理编号为 123 的问题,你可以创建一个名为 123.feature.rst 的文件。
|
|
||||||
|
|
||||||
注意在 towncrier 中,新闻片段的类型通常由文件名的后缀决定。以下是一些常见的新闻片段类型:
|
测试结果请见[`report.html`](./report.html)
|
||||||
- .feature: 用于描述新的特性或者功能。
|
|
||||||
- .bugfix: 用于描述一个 bug 修复。
|
|
||||||
- .doc: 用于描述文档的更改。
|
|
||||||
- .removal: 用于描述移除的特性或者功能。
|
|
||||||
- .misc: 用于描述其他类型的更改。
|
|
||||||
-
|
|
||||||
在这个文件中,写下你的更改的描述。这个描述应该是简短的,通常只有一到两句话。
|
|
||||||
例如`Added support for the XYZ feature.`
|
|
||||||
|
|
||||||
#### 发布新版本
|
### :cherry_blossom:功能特性
|
||||||
自动:
|
|
||||||
运行 python publish.py
|
|
||||||
|
|
||||||
手动:
|
> 项目初创,一些涉及上传东西的接口等还未进行支持,具体可见下方未支持的接口(急需某个未支持的接口可以发issue,我会优先解决)
|
||||||
使用bumpversion自动更新版本号,提交并发布标签
|
>
|
||||||
你需要安装bumpversion然后执行
|
> 接口文档具体参考原文档[NeteaseCloudMusicApi文档](https://docs.neteasecloudmusicapi.binaryify.com)
|
||||||
```bash
|
|
||||||
bumpversion patch # for a patch level increase (e.g., 1.0.0 to 1.0.1)
|
|
||||||
bumpversion minor # for a minor level increase (e.g., 1.0.0 to 1.1.0)
|
|
||||||
bumpversion major # for a major level increase (e.g., 1.0.0 to 2.0.0)
|
|
||||||
```
|
|
||||||
|
|
||||||
接下来会自动更新版本号并提交到远程仓库,然后发布一个新的标签
|
1. 登录
|
||||||
workflow会依据标签自动发布相应资源并且发布到pypi
|
2. 刷新登录
|
||||||
|
3. 发送验证码
|
||||||
|
4. 校验验证码
|
||||||
|
5. 注册(修改密码)
|
||||||
|
6. 获取用户信息 , 歌单,收藏,mv, dj 数量
|
||||||
|
7. 获取用户歌单
|
||||||
|
8. 获取用户电台
|
||||||
|
9. 获取用户关注列表
|
||||||
|
10. 获取用户粉丝列表
|
||||||
|
11. 获取用户动态
|
||||||
|
12. 获取用户播放记录
|
||||||
|
13. 获取精品歌单
|
||||||
|
14. 获取歌单详情
|
||||||
|
15. 搜索
|
||||||
|
16. 搜索建议
|
||||||
|
17. 获取歌词
|
||||||
|
18. 歌曲评论
|
||||||
|
19. 收藏单曲到歌单
|
||||||
|
20. 专辑评论
|
||||||
|
21. 歌单评论
|
||||||
|
22. mv 评论
|
||||||
|
23. 电台节目评论
|
||||||
|
24. banner
|
||||||
|
25. 获取歌曲详情
|
||||||
|
26. 获取专辑内容
|
||||||
|
27. 获取歌手单曲
|
||||||
|
28. 获取歌手 mv
|
||||||
|
29. 获取歌手专辑
|
||||||
|
30. 获取歌手描述
|
||||||
|
31. 获取相似歌手
|
||||||
|
32. 获取相似歌单
|
||||||
|
33. 相似 mv
|
||||||
|
34. 获取相似音乐
|
||||||
|
35. 获取最近 5 个听了这首歌的用户
|
||||||
|
36. 获取每日推荐歌单
|
||||||
|
37. 获取每日推荐歌曲
|
||||||
|
38. 私人 FM
|
||||||
|
39. 签到
|
||||||
|
40. 喜欢音乐
|
||||||
|
41. 垃圾桶
|
||||||
|
42. 歌单 ( 网友精选碟 )
|
||||||
|
43. 新碟上架
|
||||||
|
44. 热门歌手
|
||||||
|
45. 最新 mv
|
||||||
|
46. 推荐 mv
|
||||||
|
47. 推荐歌单
|
||||||
|
48. 推荐新音乐
|
||||||
|
49. 推荐电台
|
||||||
|
50. 推荐节目
|
||||||
|
51. 独家放送
|
||||||
|
52. mv 排行
|
||||||
|
53. 获取 mv 数据
|
||||||
|
54. 播放 mv/视频
|
||||||
|
55. 排行榜
|
||||||
|
56. 歌手榜
|
||||||
|
57. 云盘
|
||||||
|
58. 电台 - 推荐
|
||||||
|
59. 电台 - 分类
|
||||||
|
60. 电台 - 分类推荐
|
||||||
|
61. 电台 - 订阅
|
||||||
|
62. 电台 - 详情
|
||||||
|
63. 电台 - 节目
|
||||||
|
64. 给评论点赞
|
||||||
|
65. 获取动态
|
||||||
|
66. 热搜列表(简略)
|
||||||
|
67. 发送私信
|
||||||
|
68. 发送私信歌单
|
||||||
|
69. 新建歌单
|
||||||
|
70. 收藏/取消收藏歌单
|
||||||
|
71. 歌单分类
|
||||||
|
72. 收藏的歌手列表
|
||||||
|
73. 订阅的电台列表
|
||||||
|
74. 相关歌单推荐
|
||||||
|
75. 付费精选接口
|
||||||
|
76. 音乐是否可用检查接口
|
||||||
|
77. 登录状态
|
||||||
|
78. 获取视频播放地址
|
||||||
|
79. 发送/删除评论
|
||||||
|
80. 热门评论
|
||||||
|
81. 视频评论
|
||||||
|
82. 退出登录
|
||||||
|
83. 所有榜单
|
||||||
|
84. 所有榜单内容摘要
|
||||||
|
85. 收藏视频
|
||||||
|
86. 收藏 MV
|
||||||
|
87. 视频详情
|
||||||
|
88. 相关视频
|
||||||
|
89. 关注用户
|
||||||
|
90. 新歌速递
|
||||||
|
91. 喜欢音乐列表(无序)
|
||||||
|
92. 收藏的 MV 列表
|
||||||
|
93. 获取最新专辑
|
||||||
|
94. 听歌打卡
|
||||||
|
95. 获取视频标签/分类下的视频
|
||||||
|
96. 已收藏专辑列表
|
||||||
|
97. 获取动态评论
|
||||||
|
98. 歌单收藏者列表
|
||||||
|
99. 云盘歌曲删除
|
||||||
|
100. 热门话题
|
||||||
|
101. 电台 - 推荐类型
|
||||||
|
102. 电台 - 非热门类型
|
||||||
|
103. 电台 - 今日优选
|
||||||
|
104. 心动模式/智能播放
|
||||||
|
105. 转发动态
|
||||||
|
106. 删除动态
|
||||||
|
107. 分享歌曲、歌单、mv、电台、电台节目到动态
|
||||||
|
108. 通知-私信
|
||||||
|
109. 通知-评论
|
||||||
|
110. 通知-@我
|
||||||
|
111. 通知-通知
|
||||||
|
112. 设置
|
||||||
|
113. 云盘数据详情
|
||||||
|
114. 私信内容
|
||||||
|
115. 我的数字专辑
|
||||||
|
116. batch批量请求接口
|
||||||
|
117. 获取视频标签列表
|
||||||
|
118. 全部mv
|
||||||
|
119. 网易出品mv
|
||||||
|
120. 收藏/取消收藏专辑
|
||||||
|
121. 专辑动态信息
|
||||||
|
122. 热搜列表(详细)
|
||||||
|
123. 更换绑定手机
|
||||||
|
124. 检测手机号码是否已注册
|
||||||
|
125. 初始化昵称
|
||||||
|
126. 更新歌单描述
|
||||||
|
127. 更新歌单名
|
||||||
|
128. 更新歌单标签
|
||||||
|
129. 默认搜索关键词
|
||||||
|
130. 删除歌单
|
||||||
|
131. 电台banner
|
||||||
|
132. 用户电台
|
||||||
|
133. 热门电台
|
||||||
|
134. 电台 - 节目详情
|
||||||
|
135. 电台 - 节目榜
|
||||||
|
136. 电台 - 新晋电台榜/热门电台榜
|
||||||
|
137. 类别热门电台
|
||||||
|
138. 云村热评
|
||||||
|
139. 电台24小时节目榜
|
||||||
|
140. 电台24小时主播榜
|
||||||
|
141. 电台最热主播榜
|
||||||
|
142. 电台主播新人榜
|
||||||
|
143. 电台付费精品榜
|
||||||
|
144. 歌手热门50首歌曲
|
||||||
|
145. 购买数字专辑
|
||||||
|
146. 获取 mv 点赞转发评论数数据
|
||||||
|
147. 获取视频点赞转发评论数数据
|
||||||
|
148. 调整歌单顺序
|
||||||
|
149. 调整歌曲顺序
|
||||||
|
150. 独家放送列表
|
||||||
|
151. 获取推荐视频
|
||||||
|
152. 获取视频分类列表
|
||||||
|
153. 获取全部视频列表接口
|
||||||
|
154. 获取历史日推可用日期列表
|
||||||
|
155. 获取历史日推详细数据
|
||||||
|
156. 国家编码列表
|
||||||
|
157. 首页-发现
|
||||||
|
158. 首页-发现-圆形图标入口列表
|
||||||
|
159. 数字专辑-全部新碟
|
||||||
|
160. 数字专辑-热门新碟
|
||||||
|
161. 数字专辑&数字单曲-榜单
|
||||||
|
162. 数字专辑-语种风格馆
|
||||||
|
163. 数字专辑详情
|
||||||
|
164. 更新头像
|
||||||
|
165. 歌单封面上传
|
||||||
|
166. 楼层评论
|
||||||
|
167. 歌手全部歌曲
|
||||||
|
168. 精品歌单标签列表
|
||||||
|
169. 用户等级信息
|
||||||
|
170. 电台个性推荐
|
||||||
|
171. 用户绑定信息
|
||||||
|
172. 用户绑定手机
|
||||||
|
173. 新版评论
|
||||||
|
174. 点赞过的视频
|
||||||
|
175. 收藏视频到视频歌单
|
||||||
|
176. 删除视频歌单里的视频
|
||||||
|
177. 最近播放的视频
|
||||||
|
178. 音乐日历
|
||||||
|
179. 电台订阅者列表
|
||||||
|
180. 云贝签到信息
|
||||||
|
181. 云贝签到
|
||||||
|
182. 云贝所有任务
|
||||||
|
183. 云贝todo任务
|
||||||
|
184. 云贝今日签到信息
|
||||||
|
185. 云贝完成任务
|
||||||
|
186. 云贝收入
|
||||||
|
187. 云贝支出
|
||||||
|
188. 云贝账户信息
|
||||||
|
189. 账号信息
|
||||||
|
190. 最近联系人
|
||||||
|
191. 私信音乐
|
||||||
|
192. 抱一抱评论
|
||||||
|
193. 评论抱一抱列表
|
||||||
|
194. 收藏的专栏
|
||||||
|
195. 关注歌手新歌
|
||||||
|
196. 关注歌手新MV
|
||||||
|
197. 歌手详情
|
||||||
|
198. 云盘上传
|
||||||
|
199. 二维码登录
|
||||||
|
200. 话题详情
|
||||||
|
201. 话题详情热门动态
|
||||||
|
202. 歌单详情动态
|
||||||
|
203. 绑定手机
|
||||||
|
204. 一起听状态
|
||||||
|
205. 用户历史评论
|
||||||
|
206. 云盘歌曲信息匹配纠正
|
||||||
|
207. 云贝推歌
|
||||||
|
208. 云贝推歌历史记录
|
||||||
|
209. 已购单曲
|
||||||
|
210. 获取mlog播放地址
|
||||||
|
211. 将mlog id转为视频id
|
||||||
|
212. vip成长值
|
||||||
|
213. vip成长值获取记录
|
||||||
|
214. vip任务
|
||||||
|
215. 领取vip成长值
|
||||||
|
216. 歌手粉丝
|
||||||
|
217. 数字专辑详情
|
||||||
|
218. 数字专辑销量
|
||||||
|
219. 音乐人数据概况
|
||||||
|
220. 音乐人播放趋势
|
||||||
|
221. 音乐人任务
|
||||||
|
222. 账号云豆数
|
||||||
|
223. 领取云豆
|
||||||
|
224. 获取 VIP 信息
|
||||||
|
225. 音乐人签到
|
||||||
|
226. 发送文本动态
|
||||||
|
227. 获取客户端歌曲下载 url
|
||||||
|
228. 获取歌单所有歌曲
|
||||||
|
229. 乐签信息
|
||||||
|
230. 最近播放-歌曲
|
||||||
|
231. 最近播放-视频
|
||||||
|
232. 最近播放-声音
|
||||||
|
233. 最近播放-歌单
|
||||||
|
234. 最近播放-专辑
|
||||||
|
235. 最近播放-播客
|
||||||
|
236. 签到进度
|
||||||
|
237. 重复昵称检测
|
||||||
|
238. 歌手粉丝数量
|
||||||
|
239. 音乐人任务(新)
|
||||||
|
240. 内部版本接口
|
||||||
|
241. 歌单更新播放量
|
||||||
|
242. 黑胶时光机
|
||||||
|
243. 音乐百科 - 简要信息
|
||||||
|
244. 乐谱列表
|
||||||
|
245. 乐谱内容
|
||||||
|
246. 曲风列表
|
||||||
|
247. 曲风偏好
|
||||||
|
248. 曲风详情
|
||||||
|
249. 曲风-歌曲
|
||||||
|
250. 曲风-专辑
|
||||||
|
251. 曲风-歌单
|
||||||
|
252. 曲风-歌手
|
||||||
|
253. 私信和通知接口
|
||||||
|
254. 回忆坐标
|
||||||
|
255. 播客搜索
|
||||||
|
256. 播客声音上传
|
||||||
|
257. 验证接口-二维码生成
|
||||||
|
258. 验证接口-二维码检测
|
||||||
|
259. 听歌识曲
|
||||||
|
260. 根据nickname获取userid接口
|
||||||
|
261. 播客声音列表
|
||||||
|
262. 专辑简要百科信息
|
||||||
|
263. 歌曲简要百科信息
|
||||||
|
264. 歌手简要百科信息
|
||||||
|
265. mv简要百科信息
|
||||||
|
266. 搜索歌手
|
||||||
|
267. 用户贡献内容
|
||||||
|
268. 用户贡献条目、积分、云贝数量
|
||||||
|
269. 年度听歌报告
|
||||||
|
270. 播客声音搜索
|
||||||
|
|
||||||
### 改进
|
### 改进
|
||||||
> 下列API未支持
|
> 下列API未支持
|
||||||
>
|
>
|
||||||
- apicache.js
|
|
||||||
- memory-cache.js
|
|
||||||
- request_reference.js
|
- request_reference.js
|
||||||
- avatar_upload.js
|
- avatar_upload.js
|
||||||
- cloud.js
|
- cloud.js
|
||||||
@ -124,9 +415,4 @@ workflow会依据标签自动发布相应资源并且发布到pypi
|
|||||||
- /daily_signin
|
- /daily_signin
|
||||||
- /fm_trash
|
- /fm_trash
|
||||||
|
|
||||||
### 欢迎提交PR
|
### 欢迎提交PR
|
||||||
|
|
||||||
更正request库返回多个cookie时自动用分号拼接导致后续cookie不好解析的问题
|
|
||||||
添加了对cookie中Max-Age为0的处理
|
|
||||||
改进判断cookie是否过期的逻辑
|
|
||||||
添加了自动处理cookie的更新操作
|
|
43
docs/开发指南.md
Normal file
43
docs/开发指南.md
Normal file
@ -0,0 +1,43 @@
|
|||||||
|
# 写个开发者的开发指南
|
||||||
|
|
||||||
|
### 开发
|
||||||
|
- 克隆项目 `git clone git@github.com:2061360308/NeteaseCloudMusic_PythonSDK.git`
|
||||||
|
- 安装依赖 `pip install -r requirements.txt`
|
||||||
|
- 目录/文件说明
|
||||||
|
```
|
||||||
|
├── package 项目包根目录
|
||||||
|
├── test_gender 生成测试代码的脚本
|
||||||
|
├── test.py 手动测试/ 使用示例
|
||||||
|
```
|
||||||
|
|
||||||
|
#### 更新
|
||||||
|
项目使用towncrier自动生成更新日志
|
||||||
|
|
||||||
|
在 newsfragments 目录下,创建一个新的文本文件。这个文件的名字应该是一个唯一的编号,后缀是 .rst。
|
||||||
|
例如,如果你正在处理编号为 123 的问题,你可以创建一个名为 123.feature.rst 的文件。
|
||||||
|
|
||||||
|
注意在 towncrier 中,新闻片段的类型通常由文件名的后缀决定。以下是一些常见的新闻片段类型:
|
||||||
|
- .feature: 用于描述新的特性或者功能。
|
||||||
|
- .bugfix: 用于描述一个 bug 修复。
|
||||||
|
- .doc: 用于描述文档的更改。
|
||||||
|
- .removal: 用于描述移除的特性或者功能。
|
||||||
|
- .misc: 用于描述其他类型的更改。
|
||||||
|
-
|
||||||
|
在这个文件中,写下你的更改的描述。这个描述应该是简短的,通常只有一到两句话。
|
||||||
|
例如`Added support for the XYZ feature.`
|
||||||
|
|
||||||
|
#### 发布新版本
|
||||||
|
自动:
|
||||||
|
运行 python publish.py
|
||||||
|
|
||||||
|
手动:
|
||||||
|
使用bumpversion自动更新版本号,提交并发布标签
|
||||||
|
你需要安装bumpversion然后执行
|
||||||
|
```bash
|
||||||
|
bumpversion patch # for a patch level increase (e.g., 1.0.0 to 1.0.1)
|
||||||
|
bumpversion minor # for a minor level increase (e.g., 1.0.0 to 1.1.0)
|
||||||
|
bumpversion major # for a major level increase (e.g., 1.0.0 to 2.0.0)
|
||||||
|
```
|
||||||
|
|
||||||
|
接下来会自动更新版本号并提交到远程仓库,然后发布一个新的标签
|
||||||
|
workflow会依据标签自动发布相应资源并且发布到pypi
|
File diff suppressed because one or more lines are too long
@ -524,6 +524,18 @@
|
|||||||
}
|
}
|
||||||
]
|
]
|
||||||
},
|
},
|
||||||
|
"/search": {
|
||||||
|
"name": "搜索",
|
||||||
|
"explain": "调用此接口 , 传入搜索关键词可以搜索该音乐 / 专辑 / 歌手 / 歌单 / 用户 , 关键词可以多个 , 以空格隔开 , 如 \" 周杰伦 搁浅 \"( 不需要登录 ), 可通过 /song/url 接口传入歌曲 id 获取具体的播放链接",
|
||||||
|
"example": [
|
||||||
|
{
|
||||||
|
"query": {
|
||||||
|
"keywords": "海阔天空"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
]
|
||||||
|
|
||||||
|
},
|
||||||
"/search/hot": {
|
"/search/hot": {
|
||||||
"name": "热搜列表(简略)",
|
"name": "热搜列表(简略)",
|
||||||
"explain": "说明 : 调用此接口,可获取热门搜索列表",
|
"explain": "说明 : 调用此接口,可获取热门搜索列表",
|
||||||
|
@ -181,17 +181,20 @@ class NeteaseCloudMusicApi:
|
|||||||
def call_api(self, name, query):
|
def call_api(self, name, query):
|
||||||
request_param = self.ctx.call('NeteaseCloudMusicApi.beforeRequest', name, query) # 拿到请求头和请求参数
|
request_param = self.ctx.call('NeteaseCloudMusicApi.beforeRequest', name, query) # 拿到请求头和请求参数
|
||||||
|
|
||||||
|
# print(request_param)
|
||||||
|
|
||||||
# Todo 了解 py_mini_racer 返回没有自动编码 而 node可以
|
# Todo 了解 py_mini_racer 返回没有自动编码 而 node可以
|
||||||
param_data = {}
|
# from urllib.parse import unquote
|
||||||
if request_param["data"] != "":
|
# param_data = {}
|
||||||
for item in request_param["data"].split("&"):
|
# if request_param["data"] != "":
|
||||||
# param_data[item.split("=")[0]] = urllib.parse.quote(item.split("=")[1], safe='') # 不需要编码后反而出错
|
# for item in request_param["data"].split("&"):
|
||||||
param_data[item.split("=")[0]] = item.split("=")[1]
|
# # param_data[item.split("=")[0]] = urllib.parse.quote(item.split("=")[1], safe='') # 不需要编码后反而出错
|
||||||
|
# param_data[item.split("=")[0]] = unquote(item.split("=")[1])
|
||||||
|
|
||||||
if request_param.get("method") == "GET":
|
if request_param.get("method") == "GET":
|
||||||
response = requests.get(request_param["url"], params=param_data, headers=request_param["headers"])
|
response = requests.get(request_param["url"], params=request_param['data'], headers=request_param["headers"])
|
||||||
else:
|
else:
|
||||||
response = requests.post(request_param["url"], data=param_data, headers=request_param["headers"])
|
response = requests.post(request_param["url"], data=request_param['data'], headers=request_param["headers"])
|
||||||
|
|
||||||
try:
|
try:
|
||||||
data = json.loads(response.text)
|
data = json.loads(response.text)
|
||||||
@ -205,7 +208,7 @@ class NeteaseCloudMusicApi:
|
|||||||
}
|
}
|
||||||
|
|
||||||
result = self.ctx.call('NeteaseCloudMusicApi.afterRequest',
|
result = self.ctx.call('NeteaseCloudMusicApi.afterRequest',
|
||||||
json.dumps(response_result),
|
response_result,
|
||||||
request_param.get('crypto', None),
|
request_param.get('crypto', None),
|
||||||
request_param['apiName']) # 拿到请求结果
|
request_param['apiName']) # 拿到请求结果
|
||||||
|
|
||||||
|
BIN
static/Python.jpg
Normal file
BIN
static/Python.jpg
Normal file
Binary file not shown.
After Width: | Height: | Size: 11 KiB |
BIN
static/Qt.jpg
Normal file
BIN
static/Qt.jpg
Normal file
Binary file not shown.
After Width: | Height: | Size: 14 KiB |
BIN
static/idea.jpg
Normal file
BIN
static/idea.jpg
Normal file
Binary file not shown.
After Width: | Height: | Size: 33 KiB |
BIN
static/javascript.jpg
Normal file
BIN
static/javascript.jpg
Normal file
Binary file not shown.
After Width: | Height: | Size: 16 KiB |
BIN
static/wish.jpg
Normal file
BIN
static/wish.jpg
Normal file
Binary file not shown.
After Width: | Height: | Size: 19 KiB |
BIN
static/网易云.png
Normal file
BIN
static/网易云.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 9.5 KiB |
12
test.py
12
test.py
@ -7,7 +7,7 @@ from enum import Enum
|
|||||||
from pprint import pprint
|
from pprint import pprint
|
||||||
import dotenv
|
import dotenv
|
||||||
|
|
||||||
from NeteaseCloudMusic import NeteaseCloudMusicApi, api_help, api_list
|
from package.NeteaseCloudMusic import NeteaseCloudMusicApi, api_help, api_list
|
||||||
|
|
||||||
# from NeteaseCloudMusic import NeteaseCloudMusicApi, api_help, api_list
|
# from NeteaseCloudMusic import NeteaseCloudMusicApi, api_help, api_list
|
||||||
|
|
||||||
@ -108,13 +108,18 @@ def login_refresh():
|
|||||||
pprint(response)
|
pprint(response)
|
||||||
|
|
||||||
|
|
||||||
|
def login_status():
|
||||||
|
response = netease_cloud_music_api.request("login_status")
|
||||||
|
pprint(response)
|
||||||
|
|
||||||
|
|
||||||
if __name__ == '__main__':
|
if __name__ == '__main__':
|
||||||
pass
|
pass
|
||||||
# print(api_list())
|
# print(api_list())
|
||||||
# print(api_help())
|
# print(api_help())
|
||||||
# song_url_v1_test()
|
# song_url_v1_test()
|
||||||
# top_mv_test()
|
# top_mv_test()
|
||||||
# search_test()
|
search_test()
|
||||||
# search_default_test()
|
# search_default_test()
|
||||||
# comment_new_test()
|
# comment_new_test()
|
||||||
# toplist_detail_test()
|
# toplist_detail_test()
|
||||||
@ -124,4 +129,5 @@ if __name__ == '__main__':
|
|||||||
# login_cellphone_test()
|
# login_cellphone_test()
|
||||||
# user_account_test()
|
# user_account_test()
|
||||||
# playlist_track_all_test()
|
# playlist_track_all_test()
|
||||||
login_refresh()
|
# login_refresh()
|
||||||
|
# login_status()
|
||||||
|
Loading…
Reference in New Issue
Block a user