监控日本某卖衣服网站新品发布,第一时间邮件通知

本文介绍了一个使用Python的requests库和BeautifulSoup实现的简单系统,该系统每10秒检查一次特定网页上的商品列表,以判断是否有新品发布。一旦发现商品编号发生变化,即视为有新品上线,系统将通过邮件通知用户。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

网址:http://matenrow.net/17.html

 

需求是,当有新品发布时,能立即收到邮件提醒。因为抢单的人很少,所以只需要完成提醒就行。

思路就是,利用python的requests库间隔10秒去获取下网页内容,检测商品列表中第一个商品的商品编号是否改变,如果改变就说明是新品,需要发送邮件。

封装了下worker类,主要函数在check中:

import requests
import traceback
import time
from bs4 import BeautifulSoup
import logging
from send_email import SendMail
logging.basicConfig(filename='watch.log', level=logging.WARNING,
                    format='%(asctime)s %(filename)s[line:%(lineno)d] %(message)s', datefmt='%a, %d %b %Y %H:%M:%S')

class Worker():
    def __init__(self,start):
        self.start=start
        self.firstStart=True

    def check(self):
        logging.warning("old:"+self.start)
        s=requests.Session()
        ret=s.get("http://matenrow.net/17.html")
        soup_string = BeautifulSoup(ret.content, "html.parser")
        book_a = soup_string.findAll(attrs={"class": "M9_1_font_other"})
        book=book_a[0]
        if book.string!=self.start:
            self.start=book.string
            logging.warning("old:{},new:{}".format(self.start,book.string))
            return True
        else:
            return False

 接下来就是放到一个循环中,sleep10秒去执行下:

if __name__ == '__main__':
    worker=Worker("G1960")
    while True:
        try:
            ret=worker.check()
            logging.warning(ret)
            if worker.firstStart:
                worker.firstStart=False
                continue
            if ret:
                SendMail("xxxx@qq.com","提醒新产品","标号:{}".format(worker.start))
        except Exception as e:
            logging.warning("err:{},trace:{}".format(str(e),traceback.format_exc()))
        time.sleep(10)

发送邮件SendMail的代码, 可参考这篇博客

### 使用 `ON DUPLICATE KEY UPDATE` 更新所有字段但排除主键MySQL 中,当使用 `ON DUPLICATE KEY UPDATE` 语句时,如果希望更新主键外的所有字段,可以通过显式列出需要更新的字段来实现。由于主键通常设置为 `AUTO_INCREMENT` 具有唯一性约束,因此在插入更新操作中不应直接修改主键字段。 #### 示例 假设有一个名为 `employees` 的表,定义如下: ```sql CREATE TABLE employees ( id INT AUTO_INCREMENT PRIMARY KEY, name VARCHAR(100), department VARCHAR(50), salary DECIMAL(10, 2) ); ``` 现在需要插入一条记录,如果 `id` 冲突(例如,表中已存在相同的主键),则更新主键外的所有字段: ```sql INSERT INTO employees (id, name, department, salary) VALUES (101, 'Alice', 'Engineering', 85000.00) ON DUPLICATE KEY UPDATE name = 'Alice', department = 'Engineering', salary = 85000.00; ``` 在这个例子中,如果 `id = 101` 的记录已经存在,则会更新 `name`、`department` 和 `salary` 字段;如果不存在,则插入新记录。主键 `id` 在插入时指定,但在更新时不被修改 [^4]。 #### 使用 `VALUES()` 函数简化更新语句 当插入的数据较多时,可以使用 `VALUES()` 函数来引用插入时的值,从而简化更新语句: ```sql INSERT INTO employees (id, name, department, salary) VALUES (101, 'Alice', 'Engineering', 85000.00), (102, 'Bob', 'Marketing', 75000.00) ON DUPLICATE KEY UPDATE name = VALUES(name), department = VALUES(department), salary = VALUES(salary); ``` 在这个例子中,如果 `id` 冲突,`ON DUPLICATE KEY UPDATE` 子句会使用当前插入的值来更新对应的 `name`、`department` 和 `salary` 字段 [^4]。 #### 注意事项 - `ON DUPLICATE KEY UPDATE` 需要表中存在主键唯一索引,否则不会触发更新操作 [^1]。 - 如果更新的字段包含主键唯一索引列,并且更新后的值与其他记录冲突,会导致插入和更新都失败。 - 使用 `ON DUPLICATE KEY UPDATE` 时,自增字段(`AUTO_INCREMENT`)可能会跳过某些值,因为每次插入操作都会尝试分配一个新的自增值,即使最终执的是更新操作 [^3]。
评论 8
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值