api对excel文件的上传下载操作

1. 如果请求头里有:  代表下载的excel文件流需要一个文件写入

X-Requested-With:  XMLHttpRequest

    def download_order(self, kwargs):
        """下载导入模板"""
        # print(kwargs)

        result = self.request.do_request(method=kwargs["method"],
                                         url=self.url + kwargs["path"],
                                         data=kwargs["data"],
                                         headers=self.Cookie)
        if result.text:  # 判断文件是否为空
            with open(path + "/data/pool.xlsx", "wb") as pool:
                logger.info("联营模板开始写入")
                for data in result.iter_content(chunk_size=1):  # iter_content循环读取信息写入,chunk_size设置文件大小
                    pool.write(data)

        else:
            logger.info("联营excel返回结果是空的")

2. 如果请求头里有: 那么就不是普通的excel上传

        Content-Type: multipart/form-data

# 需要下载: pip install requests_toolbelt
from requests_toolbelt import MultipartEncoder   

 def out_pool(self, kwargs):
        """联营订单导入"""
        file = open(path + "/data/pool.xlsx", "rb") # 打开文件流
        # fields={"name":(文件名,文件流)}
        data = MultipartEncoder(fields={"name": ("pool.xlsx", file)})   
        header_data = {"Content-Type": data.content_type} # 固定语法
        header_data.update(self.Cookie) # 拼接cookie
        # print(header_data)
        result = self.request.do_request(method=kwargs["method"],
                                         url=self.url + kwargs["path"],
                                         data=data,
                                         headers=header_data)
        file.close()
        logger.info(result.json())

3. 上传excel明明有数据却提示无数据:

def just_excel():  # 重新打开excel并保存,必填,否则报错 ,固定语法,只需修改文件路径

    excel = Dispatch("Excel.Application")  # 模拟打开 office
    excel.Visible = False
    work = excel.Workbooks.Open(
        os.path.abspath(os.path.dirname(__file__)).rsplit("\\", 1)[0] + "\data\pool.xlsx")  # 必须写绝对路径
    work.Save()  # 保存文档
    work.Close()  # 关闭文档

    excel.Workbooks.Close()  # 保存并关闭文档
    excel.Quit()  # 关闭excel

4. 读取excel会有警告信息

from win32com.client.dynamic import Dispatch

warnings.simplefilter('ignore')  # 忽略警告,将此段放在读取excel函数中

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值