Soul Ferryman 2022-04-26 16:26 采纳率: 50%
浏览 97
已结题

Python 下载amazon 主图图片


import requests
import xlwings
from selenium import webdriver

def download_image(image_url,ASIN):
    #下载图片
    resp = requests.get(image_url, headers=headers)
    file_path = 'E:/Download/BASIN/' + ASIN + '.jpg'
    with open(file_path,'wb') as f:
        f.write(resp.content)

def get_image_url(ASIN):
    #获得图片地址
    url = 'https://www.amazon.com/dp/' + ASIN
    browser.get(url)
    img_element = browser.find_element_by_xpath('.//div[@id="imgTagWrapperId"]/img')
    image_url = img_element.get_attribute('data-old-hires')
    return image_url

app = xlwings.App()
wb = app.books.open('E:/Download/BASIN/Casin.xlsx')
ws = wb.sheets('1')
ASINS = ws.range('a2:a3').value #打开excel文件读取需要爬取主图的asin
browser = webdriver.Chrome()
headers = {
    'User-Agent':'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/100.0.4896.127 Safari/537.36',
}
image_news = []
for ASIN in ASINS:
    print(ASINS.index(ASIN)+1, ASIN)
    try:
        image_url = get_image_url(ASIN)
        download_image(image_url,ASIN)
        image_news.append('已下载')
    except:
        image_news.append('没找到')

ws.range('g2').options(transpose=True).value = image_news #在g列写下下载结果
wb.save()
app.quit()
browser.close()

上面的代码是我复制别人的来改的 就是改了文件路径
下面是报错提示
D:\Users\TY\AppData\Local\Programs\Python\Python310\python.exe C:/Users/TY/PycharmProjects/pythonProject5/main.py
Traceback (most recent call last):
File "C:\Users\TY\PycharmProjects\pythonProject5\main.py", line 22, in
ws = wb.sheets('1')
File "D:\Users\TY\AppData\Local\Programs\Python\Python310\lib\site-packages\xlwings\main.py", line 4893, in call
return Sheet(impl=self.impl(name_or_index))
File "D:\Users\TY\AppData\Local\Programs\Python\Python310\lib\site-packages\xlwings_xlwindows.py", line 877, in call
return Sheet(xl=self.xl(name_or_index))
File "D:\Users\TY\AppData\Local\Programs\Python\Python310\lib\site-packages\xlwings_xlwindows.py", line 208, in call
v = self._inner(*args, **kwargs)
File "C:\Users\TY\AppData\Local\Temp\gen_py\3.10\00020813-0000-0000-C000-000000000046x0x1x9.py", line 36625, in call
ret = self.oleobj.InvokeTypes(0, LCID, 2, (9, 0), ((12, 1),),Index
pywintypes.com_error: (-2147352567, '发生意外。', (0, None, None, None, 0, -2147352565), None)

进程已结束,退出代码1

ASIN在表格sheet1种
有没有人帮我改下啊 谢谢

  • 写回答

1条回答 默认 最新

  • llc的足迹 2022-04-26 16:34
    关注

    Casin.xlsx 这个excel表格中是有数据的,你的是不是没有数据?

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

问题事件

  • 系统已结题 5月4日
  • 已采纳回答 4月26日
  • 修改了问题 4月26日
  • 赞助了问题酬金10元 4月26日
  • 展开全部

悬赏问题

  • ¥30 基于信创PC发布的QT应用如何跨用户启动后输入中文
  • ¥20 非root手机,如何精准控制手机流量消耗的大小,如20M
  • ¥15 远程安装一下vasp
  • ¥15 自己做的代码上传图片时,报错
  • ¥15 Lingo线性规划模型怎么搭建
  • ¥15 关于#python#的问题,请各位专家解答!区间型正向化
  • ¥15 unity从3D升级到urp管线,打包ab包后,材质全部变紫色
  • ¥50 comsol温度场仿真无法模拟微米级激光光斑
  • ¥15 上传图片时提交的存储类型
  • ¥15 VB.NET如何绘制倾斜的椭圆