鱼C论坛

 找回密码
 立即注册
查看: 1319|回复: 3

[已解决]求位懂java的大佬看看这个代码

[复制链接]
发表于 2021-9-12 16:27:14 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
import cn.hutool.http.HttpRequest;
import cn.hutool.http.HttpUtil;
import com.alibaba.fastjson.JSONArray;
import com.alibaba.fastjson.JSONObject;

/**
 * @author ohy
 * @date 2021-08-26 09:59:38
 **/
public class Test {

    static String cookie ="";

    public static void main(String[] args) {
        String url = "https://drive.kdocs.cn/api/v5/links?offset=0&count=100&orderby=file_mtime&order=DESC&append=false&ignore=link";
        String res = HttpRequest.get(url).header("cookie", cookie).execute().body();
        JSONObject jsonObject = JSONObject.parseObject(res);
        String path = "C:\\Users\\montnets\\Desktop\\test\"
                + jsonObject.getJSONArray("share").getJSONObject(0).getString("share_name");
        parseGroup(jsonObject.getJSONArray("share").getJSONObject(0).getJSONObject("group").getString("groupid"), path, "0");
    }

    private static void parseGroup(String id, String path, String parentId) {
        String url = "https://drive.kdocs.cn/api/v5/groups/" + id + "/files?linkgroup=true&include=acl,pic_thumbnail&offset=0&count=30";
        if (!parentId.equals("0")) url += "&parentid=" + parentId;
        String res = HttpRequest.get(url).header("cookie", cookie).execute().body();
        JSONObject jsonObject = JSONObject.parseObject(res);
        JSONArray array = jsonObject.getJSONArray("files");
        for (int i = 0; i < array.size(); i++) {
            JSONObject object = array.getJSONObject(i);
            if (object.getString("ftype").equals("folder")) {
                String groupId = object.getString("id");
                String name = object.getString("fname");
                parseGroup(id, path + "\" + name, groupId);
            } else if (object.getString("ftype").equals("file")) {
                String fId = object.getString("id");
                String name = object.getString("fname");
                String getdownUrl = "https://drive.kdocs.cn/api/v3/groups/" + id + "/files/" + fId + "/download?isblocks=false";
                res = HttpRequest.get(getdownUrl).header("cookie", cookie).execute().body();
                String downUrl = JSONObject.parseObject(res).getJSONObject("fileinfo").getString("url");
                HttpUtil.downloadFile(downUrl, path + "/" + name);
            }
        }
    }
}

主要是看不懂java的代码,求大佬帮忙看看能不能给整成python的样式
最佳答案
2021-9-12 16:48:12
url1 = "https://drive.kdocs.cn/api/v5/links?offset=0&count=100&orderby=file_mtime&order=DESC&append=false&ignore=link"
url2 = f"https://drive.kdocs.cn/api/v5/groups/" + {id} + "/files?linkgroup=true&include=acl,pic_thumbnail&offset=0&count=30"
#实例一下
res1  = requests.get(url1)
id_list = res1.json().get('id')
for id in id_list:
    url2 = f"https://drive.kdocs.cn/api/v5/groups/" + {id} + "/files?linkgroup=true&include=acl,pic_thumbnail&offset=0&count=30"
    resp2 = requests.get(url)
    with open(f'{id}',mode='wb',encoding='UTF-8') as file:
       file.write(resp2.content)
大概意思就是从url1的响应信息(json格式)中拿到id,id有很多个,然后循环的传到url2中,访问url2,下载个什么东东保存到本地
注意需要登录
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2021-9-12 16:48:12 | 显示全部楼层    本楼为最佳答案   
url1 = "https://drive.kdocs.cn/api/v5/links?offset=0&count=100&orderby=file_mtime&order=DESC&append=false&ignore=link"
url2 = f"https://drive.kdocs.cn/api/v5/groups/" + {id} + "/files?linkgroup=true&include=acl,pic_thumbnail&offset=0&count=30"
#实例一下
res1  = requests.get(url1)
id_list = res1.json().get('id')
for id in id_list:
    url2 = f"https://drive.kdocs.cn/api/v5/groups/" + {id} + "/files?linkgroup=true&include=acl,pic_thumbnail&offset=0&count=30"
    resp2 = requests.get(url)
    with open(f'{id}',mode='wb',encoding='UTF-8') as file:
       file.write(resp2.content)
大概意思就是从url1的响应信息(json格式)中拿到id,id有很多个,然后循环的传到url2中,访问url2,下载个什么东东保存到本地
注意需要登录
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2021-9-12 17:39:10 | 显示全部楼层

哇  果然换成python就能看懂了  感谢感谢
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2021-9-13 11:37:10 | 显示全部楼层
代码要改一下。第5行会报错。返回的结果是列表嵌套字典
url1 = "https://drive.kdocs.cn/api/v5/links?offset=0&count=100&orderby=file_mtime&order=DESC&append=false&ignore=link"
url2 = f"https://drive.kdocs.cn/api/v5/groups/" + {id} + "/files?linkgroup=true&include=acl,pic_thumbnail&offset=0&count=30"
#实例一下
res1  = requests.get(url1)
id_list = res1.json()
for id1 in id_list:
    id1 = id1.get('id')
    url2 = f"https://drive.kdocs.cn/api/v5/groups/" + {id1} + "/files?linkgroup=true&include=acl,pic_thumbnail&offset=0&count=30"
    resp2 = requests.get(url)
    with open(f'{id}',mode='wb',encoding='UTF-8') as file:
       file.write(resp2.content)
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-1-13 10:28

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表