复制from openpyxl import Workbook, load_workbook
from openpyxl.drawing.image import Image
from openpyxl.drawing.spreadsheet_drawing import AnchorMarker, TwoCellAnchor
import requests
def download(url,raw_path):
file = url.split("/")[-1]
file_name = f'{raw_path}/{file}'
if os.path.exists(file_name):
print(f"已存在{file_name}")
return
headers = {
"Accept": "text/html,application/xhtml+xml,application/xml;q=0.9,image/avif,image/webp,image/apng,*/*;q=0.8,application/signed-exchange;v=b3;q=0.9",
"Accept-Language": "zh-CN,zh;q=0.9",
"Cache-Control": "no-cache",
"Connection": "keep-alive",
"Pragma": "no-cache",
"Sec-Fetch-Dest": "document",
"Sec-Fetch-Mode": "navigate",
"Sec-Fetch-Site": "none",
"Sec-Fetch-User": "?1",
"Upgrade-Insecure-Requests": "1",
"User-Agent": "Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_7) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/103.0.0.0 Safari/537.36",
"sec-ch-ua": "\".Not/A)Brand\";v=\"99\", \"Google Chrome\";v=\"103\", \"Chromium\";v=\"103\"",
"sec-ch-ua-mobile": "?0",
"sec-ch-ua-platform": "\"macOS\""
}
res = requests.get(url,headers=headers,verify=False,)
with open(file_name,"wb") as fw:
fw.write(res.content)
def item_list_to_excel(row_list):
if not row_list:
return None
wb = Workbook()
ws = wb.create_sheet("Sheet",0)
raw_path =os.path.dirname(os.path.dirname(__file__))+"/images"
if not os.path.exists(raw_path):
os.makedirs(raw_path)
pool = ThreadPoolExecutor(20)
t_list = [ pool.submit(download,data["商品图片"],raw_path) for data in row_list ]
for t in t_list:
t.result()
column = 1
for k in row_list[0].keys():
ws.cell(row=1, column=column, value=k)
column += 1
m = 0
for data in row_list:
row_data = list(data.values())
row_count =len(row_data)
for index in range(1,row_count):
ws.cell(row=m + 1 + 1, column=index+1, value=row_data[index])
file = row_data[0].split("/")[-1]
image_path = f'{raw_path}/{file}'
img = Image(image_path)
ws.row_dimensions[m+2].height = 180
ws.column_dimensions['A'].width = 50
_from = AnchorMarker(0, 50000, m + 1, 50000)
to = AnchorMarker(1, -50000, m + 1 + 1, -50000)
img.anchor = TwoCellAnchor('twoCell', _from, to)
ws.add_image(img)
m+=1
file_name = f'export_distributor_{datetime.datetime.now().strftime("%Y%m%d_%H%M")}.xlsx'
wb.save(file_name)
wb.close()
print(f"保存文件")
return file_name
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· winform 绘制太阳,地球,月球 运作规律
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· AI与.NET技术实操系列(五):向量存储与相似性搜索在 .NET 中的实现
· 超详细:普通电脑也行Windows部署deepseek R1训练数据并当服务器共享给他人
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
2021-09-28 关于mac自带的openssl和brew安装的openssl冲突
2020-09-28 python音频文件中pcm格式提取
2019-09-28 FLask中蓝图(用于分文件)
2019-09-28 Flask框架整个流程源码解读
2019-09-28 Flask中g对象,以及g,session,flash之间的区别
2019-09-28 python类中的__str__以及__repr__