python - 如何在 API 调用中过滤带有扩展名的文件名?
问题描述
我正在使用 python confluence API 从 confluence 页面下载附件,我只需要下载带有.mpp
扩展名的文件。尝试使用glob
和直接参数,但没有用。
这是我的代码:
file_name = glob.glob("*.mpp")
attachments_container = confluence.get_attachments_from_content(page_id=33110, start=0, limit=1,filename=file_name)
print(attachments_container)
attachments = attachments_container['results']
for attachment in attachments:
fname = attachment['title']
download_link = confluence.url + attachment['_links']['download']
r = requests.get(download_link, auth = HTTPBasicAuth(confluence.username,confluence.password))
if r.status_code == 200:
if not os.path.exists('phoenix'):
os.makedirs('phoenix')
fname = ".\\phoenix\\" +fname
解决方案
glob.glob()
在您的本地文件夹上运行。因此,您不能将其用作get_attachments_from_content()
. 另外,不要指定 a limit
of 因为这只会给你一个/第一个附件。指定一个上限或任何默认值将包括所有这些。(您可能需要对结果进行分页。)
title
但是,您可以通过在下载之前检查每个附件的 来排除您不想要的文件,您拥有fname = attachment['title']
.
attachments_container = confluence.get_attachments_from_content(page_id=33110, limit=1000)
attachments = attachments_container['results']
for attachment in attachments:
fname = attachment['title']
if not fname.lower().endswith('.mpp'):
# skip file if it's not got that extension
continue
download_link = ...
# rest of your code here
此外,您的代码看起来像是来自此答案的复制粘贴,但您已经更改了它的实际“下载”部分。因此,如果您的下一个 StackOverflow 问题是“如何从 confluence 下载文件”,请使用该答案的代码。
推荐阅读
- r - 更精简的混合效应模型
- java - 仅在注销操作的情况下,如何在服务器端使 HTTP1.1 连接不持久?
- python - Python 101 - 变量名替换
- reactjs - 如何在 React 中为管理员和用户拆分代码
- git - 使用共享的私有 git 存储库
- bitbucket - 由于密码更改,无法从 bitbucket 服务器获取/提取代码
- node.js - 快递 | 发送到客户端后无法设置标头
- css - 有没有办法将高度延伸到 100% 以上?
- kubernetes - Kubernetes Graceful Shutdown:在终止期间继续服务流量
- java - 枚举值在构造函数中转换为null?