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:
|
||||
python-version: 3.
|
||||
|
||||
- name: Get the version
|
||||
id: get_version
|
||||
run: |
|
||||
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)
|
||||
|
||||
### Bugfixes
|
||||
|
384
README.md
384
README.md
@ -1,23 +1,72 @@
|
||||
# NeteaseCloudMusic_PythonSDK
|
||||
> 基于 [NeteaseCloudMusicApi](https://github.com/Binaryify/NeteaseCloudMusicApi) 封装的 Python SDK。
|
||||
> 网易云API Python版本。
|
||||
> 现已同步原项目接口且测试通过的有200多个
|
||||
> 已发布到PyPi,可直接使用pip安装
|
||||
> 项目地址:[GitHub](https://github.com/2061360308/NeteaseCloudMusic_PythonSDK)
|
||||
> 现已同步原项目接口且测试通过的有200多个:wave::wave:,:star:求赞:star:
|
||||
> 已发布到PyPi,可直接使用pip安装。项目地址:[GitHub](https://github.com/2061360308/NeteaseCloudMusic_PythonSDK)
|
||||
>
|
||||
> 在此感谢`NeteaseCloudMusicApi`项目及其作者`Binaryify`
|
||||
>
|
||||
> 当然也感谢史上最最最好用的听歌软件——网易云音乐
|
||||
>
|
||||
> 项目仅用于学习,还望大家合理使用该项目
|
||||
|
||||
![](https://img.shields.io/badge/py_mini_racer-@0.6.0-red.svg)
|
||||
![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_V8 ](https://github.com/2061360308/NeteaseCloudMusicApi_V8)
|
||||
|
||||
### 原理
|
||||
### 项目原理
|
||||
- 通过 `py_mini_racer` 调用 `NeteaseCloudMusicApi_V8` 的 `js` 方法。进一步进行了简单封装。
|
||||
|
||||
### 使用
|
||||
<div align="center">
|
||||
<img src="./static/javascript.jpg" width="474" height="266" />
|
||||
</div>
|
||||
|
||||
### :dragon_face:使用方法
|
||||
- 安装 `pip install NeteaseCloudMusic`
|
||||
- 导入API进行使用(具体查看`example.py`中的示例)
|
||||
- 导入API进行使用(具体查看[`example.py`](./example.py)中的示例)
|
||||
```python
|
||||
from NeteaseCloudMusic import NeteaseCloudMusicApi, api_help, api_list
|
||||
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`两种写法。
|
||||
|
||||
> api已加入自动缓存,在测试接口时,如果频繁调用获取结果在query里应该加上timestamp参数来区分,例如
|
||||
> api已加入自动缓存(需要自己开启默认关闭),在测试接口时,如果频繁调用获取结果在query里应该加上timestamp参数来区分,例如
|
||||
> ```python
|
||||
> response = netease_cloud_music_api.request("song_url_v1", {"id": 33894312, "level": "exhigh", "timestamp": time.time()})
|
||||
> ```
|
||||
|
||||
### 开发
|
||||
- 克隆项目 `git clone git@github.com:2061360308/NeteaseCloudMusic_PythonSDK.git`
|
||||
- 安装依赖 `pip install -r requirements.txt`
|
||||
- 目录/文件说明
|
||||
```
|
||||
├── package 项目包根目录
|
||||
├── test_gender 生成测试代码的脚本
|
||||
├── test.py 手动测试/ 使用示例
|
||||
```
|
||||
### :eyes:开发
|
||||
如果想要参与项目开发,或是自己修改源码,请参照[开发指南](./docs/开发指南.md)。
|
||||
|
||||
#### 更新
|
||||
项目使用towncrier自动生成更新日志
|
||||
### 测试
|
||||
|
||||
在 newsfragments 目录下,创建一个新的文本文件。这个文件的名字应该是一个唯一的编号,后缀是 .rst。
|
||||
例如,如果你正在处理编号为 123 的问题,你可以创建一个名为 123.feature.rst 的文件。
|
||||
测试文件见[api_test.py](./api_test.py),测试使用了`pytest`框架
|
||||
|
||||
注意在 towncrier 中,新闻片段的类型通常由文件名的后缀决定。以下是一些常见的新闻片段类型:
|
||||
- .feature: 用于描述新的特性或者功能。
|
||||
- .bugfix: 用于描述一个 bug 修复。
|
||||
- .doc: 用于描述文档的更改。
|
||||
- .removal: 用于描述移除的特性或者功能。
|
||||
- .misc: 用于描述其他类型的更改。
|
||||
-
|
||||
在这个文件中,写下你的更改的描述。这个描述应该是简短的,通常只有一到两句话。
|
||||
例如`Added support for the XYZ feature.`
|
||||
测试结果请见[`report.html`](./report.html)
|
||||
|
||||
#### 发布新版本
|
||||
自动:
|
||||
运行 python publish.py
|
||||
### :cherry_blossom:功能特性
|
||||
|
||||
手动:
|
||||
使用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)
|
||||
```
|
||||
> 项目初创,一些涉及上传东西的接口等还未进行支持,具体可见下方未支持的接口(急需某个未支持的接口可以发issue,我会优先解决)
|
||||
>
|
||||
> 接口文档具体参考原文档[NeteaseCloudMusicApi文档](https://docs.neteasecloudmusicapi.binaryify.com)
|
||||
|
||||
接下来会自动更新版本号并提交到远程仓库,然后发布一个新的标签
|
||||
workflow会依据标签自动发布相应资源并且发布到pypi
|
||||
1. 登录
|
||||
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未支持
|
||||
>
|
||||
- apicache.js
|
||||
- memory-cache.js
|
||||
- request_reference.js
|
||||
- avatar_upload.js
|
||||
- cloud.js
|
||||
@ -125,8 +416,3 @@ workflow会依据标签自动发布相应资源并且发布到pypi
|
||||
- /fm_trash
|
||||
|
||||
### 欢迎提交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": {
|
||||
"name": "热搜列表(简略)",
|
||||
"explain": "说明 : 调用此接口,可获取热门搜索列表",
|
||||
|
@ -181,17 +181,20 @@ class NeteaseCloudMusicApi:
|
||||
def call_api(self, name, query):
|
||||
request_param = self.ctx.call('NeteaseCloudMusicApi.beforeRequest', name, query) # 拿到请求头和请求参数
|
||||
|
||||
# print(request_param)
|
||||
|
||||
# Todo 了解 py_mini_racer 返回没有自动编码 而 node可以
|
||||
param_data = {}
|
||||
if request_param["data"] != "":
|
||||
for item in request_param["data"].split("&"):
|
||||
# param_data[item.split("=")[0]] = urllib.parse.quote(item.split("=")[1], safe='') # 不需要编码后反而出错
|
||||
param_data[item.split("=")[0]] = item.split("=")[1]
|
||||
# from urllib.parse import unquote
|
||||
# param_data = {}
|
||||
# if request_param["data"] != "":
|
||||
# for item in request_param["data"].split("&"):
|
||||
# # 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":
|
||||
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:
|
||||
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:
|
||||
data = json.loads(response.text)
|
||||
@ -205,7 +208,7 @@ class NeteaseCloudMusicApi:
|
||||
}
|
||||
|
||||
result = self.ctx.call('NeteaseCloudMusicApi.afterRequest',
|
||||
json.dumps(response_result),
|
||||
response_result,
|
||||
request_param.get('crypto', None),
|
||||
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
|
||||
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
|
||||
|
||||
@ -108,13 +108,18 @@ def login_refresh():
|
||||
pprint(response)
|
||||
|
||||
|
||||
def login_status():
|
||||
response = netease_cloud_music_api.request("login_status")
|
||||
pprint(response)
|
||||
|
||||
|
||||
if __name__ == '__main__':
|
||||
pass
|
||||
# print(api_list())
|
||||
# print(api_help())
|
||||
# song_url_v1_test()
|
||||
# top_mv_test()
|
||||
# search_test()
|
||||
search_test()
|
||||
# search_default_test()
|
||||
# comment_new_test()
|
||||
# toplist_detail_test()
|
||||
@ -124,4 +129,5 @@ if __name__ == '__main__':
|
||||
# login_cellphone_test()
|
||||
# user_account_test()
|
||||
# playlist_track_all_test()
|
||||
login_refresh()
|
||||
# login_refresh()
|
||||
# login_status()
|
||||
|
Loading…
Reference in New Issue
Block a user