gpt4 book ai didi

python - 使用 lxml 进行网页抓取不和谐,如何提取文本和照片链接?

转载 作者:行者123 更新时间:2023-12-01 08:07:08 25 4
gpt4 key购买 nike

我使用 lxml 从多家零售商处获取产品,并将信息发送到不和谐服务器。我已经完成了大部分工作,除了抓取链接(对于图片等:https://i5.walmartimages.com/asr/b05aca03-968b-4e43-8b48-781aa52ef3e0_1.7fa663da8e1c382271e6649007e9a60b.png?odnHeight=450&odnWidth=450&odnBg=FFFFFF)

和文本,获取商品名称和价格。

这是嵌入不和谐 Webhook 的图片

我正在尝试抓取的产品:https://www.walmart.com/ip/POP/295232252

我尝试从中提取图像的元素示例:(src=)

<img class="hover-zoom-hero-image" src="https://i5.walmartimages.com/asr/b05aca03-968b-4e43-8b48-781aa52ef3e0_1.7fa663da8e1c382271e6649007e9a60b.png?odnHeight=450&amp;odnWidth=450&amp;odnBg=FFFFFF" alt="Funko POP! Marvel: Avengers Endgame -&nbsp;Ronin">

我尝试从中提取文本的元素示例:(content=)

<h1 class="prod-ProductTitle no-margin font-normal heading-a" itemprop="name" content="Funko POP! Marvel: Avengers Endgame -&nbsp;Ronin"><div>Funko POP! Marvel: Avengers Endgame -&nbsp;Ronin</div></h1>

我的代码:

def send_embed(link):
embed = Embed(
description=link,
color=color_embed,
timestamp='now' # sets the timestamp to current time
)
image1 = 'https://www.blakleysflooring.com/wp-content/uploads/2016/03/Placeholder.png'
image2 = pic

embed.set_author(name=itemName + "|" + price, url=link)
embed.add_field(name='Retailer', value=site)
embed.add_field(name='Stock', value=instock)
embed.set_footer(text='@QuantumPings')

embed.set_thumbnail(image2)
hook.send(embed=embed)


def getDatetime():
return '[{}]'.format(str(datetime.datetime.now())[:-3])


def monitor(link):
global embed
global itemName
global pic
global site
global instock
global price
global color_embed
try:
with session as s:
r = s.get(link, timeout=10)
r.raise_for_status()

tree = etree.HTML(r.content)
if 'walmart' in link:
oos = False if tree.xpath('//span[@class="button-wrapper"]') else True
site = 'Walmart'
instock = False if tree.xpath('/html/body/div[2]/div/div/div[2]/div/div[1]/div/div[1]/div/div/div/div/div[3]/div[4]/div[2]/div[1]/div/div/div/div[4]/div/div/div[2]/div/div/div/span') else False
pic = ()
itemName = tree.xpath('//div[@class="ProductTitle"]/h2/div/text()')
price = '$0.00'
color_embed = 0x00f714 if instock is True else 0xff0008
True else 0xff0008

最佳答案

这里是如何使用 lxml 收集文本/链接的基本示例。您几乎可以使用 lxml 做任何事情,所以一定要进行实验。顺便说一句,我认为 lxmlBeautifulSoup 更快,但它没有那么优雅。我还会阅读 https://lxml.de/lxmlhtml.html

from lxml import html

response = """
<h1 class="prod-ProductTitle no-margin font-normal heading-a" itemprop="name" content="Funko POP! Marvel: Avengers Endgame -&nbsp;Ronin"><div>Funko POP! Marvel: Avengers Endgame -&nbsp;Ronin</div></h1>
<img class="hover-zoom-hero-image" src="https://i5.walmartimages.com/asr/b05aca03-968b-4e43-8b48-781aa52ef3e0_1.7fa663da8e1c382271e6649007e9a60b.png?odnHeight=450&amp;odnWidth=450&amp;odnBg=FFFFFF" alt="Funko POP! Marvel: Avengers Endgame -&nbsp;Ronin">
"""

tree = html.fromstring(response)

title = [e for e in tree.cssselect('h1') if e.get('itemprop') is not None and e.get('itemprop') == 'name']
title = title[0]
title = title.text_content()
print (title)

img = tree.cssselect('img.hover-zoom-hero-image')
img = img[0]
img = img.get('src')
print (img)

关于python - 使用 lxml 进行网页抓取不和谐,如何提取文本和照片链接?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55485094/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com