应用场景
需要进行表格导入到系统中时
注意,这里需要将 Content-Type: multipart/form-data; 进行去除,不然会报错
实现代码
# -*- ecoding: utf-8 -*-
# @ModuleName: test001
# @Function:
# @Author: darling
# @Time: 2022-03-31 15:52
import os
import sys
import time
import requests
from loguru import logger
def read_headers(file_name):
if not exists_file(file_name):
exit_sys(file_name + ' 文件不存在,请在当前目录检查必要文件')
headers = {}
with open(file_name, 'r', encoding='UTF-8') as file:
lines = file.readlines()
for line in lines:
if line == '\n':
continue
header = {}
# 这里用的是[: ]进行拆分,因为value中也会存在冒号
ll = line.split(': ')
key = ll[0].strip()
val = ll[1].strip().replace('\n', '')
header[key] = val
headers.update(header)
return headers
def exit_sys(msg):
logger.info(msg)
logger.info('程序退出··· ···')
time.sleep(3)
sys.exit()
def exists_file(file_name):
return os.path.exists(file_name)
def post_file():
url = '导入文件的url接口'
# 要上传的文件
files = {'uploadedfile': open(r'C:\Users\Administrator\Desktop\收货页面EXCEL批量导入模板20220225.xlsx', 'rb'),
'Content-Type': 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet',
'type': 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet',
'uploadType': 'html5',
'name': '收货页面EXCEL批量导入模板20220225.xlsx',
'index': 0
} # 显式的设置文件名
headers = read_headers('./header.txt')
r = requests.post(url, files=files, headers=headers)
logger.info(r.text)
if __name__ == "__main__":
post_file()