问题:使用pyquery解析html文件时,会自动闭合空标签,如何取消
解决:增加method='html'
方法:
from pyquery import PyQuery as pq
html="<div>123<h3></h3>123</div>"
d=pq(html)
print(d("div").html())
这里会输出123<h3/>123
如果想输出123<h3></h3>123
print(d('div').html(method='html'))
问题:使用pyquery解析html文件时,会自动闭合空标签,如何取消
解决:增加method='html'
方法:
from pyquery import PyQuery as pq
html="<div>123<h3></h3>123</div>"
d=pq(html)
print(d("div").html())
这里会输出123<h3/>123
如果想输出123<h3></h3>123
print(d('div').html(method='html'))
问题:使用sqlite3作为数据库, 如何查询数据
方法:
查询所有数据
Person.objects.all()
切片操作,获取10个人,不支持负索引,切片可以节约内存
Person.objects.all()[:10]
根据name查询
Person.objects.get(name = name)
get是用来获取一个对象的,如果需要获取满足条件的一些人,就要用到 filter
Person.objects.filter(name = "abc")
名称为 abc 但是不区分大小写,可以找到 ABC, Abc, aBC,这些都符合条件
Person.objects.filter(name__iexact = "abc")
问题: 如何知道本月有多少天?本月最后一天是什么?
解决: 使用calendar
方法:
import calendar
import datetime
today = datetime.date.today()
calendar.mothrange(today.year, today.month)[1]
# 使用下月月初来判断本月天数
first_day = today.replace(day=1)
next_month = today + datetime.timedelta(days=31) # 因为月份最多31天
next_first = next_month.replace(day=1)
days = (next_first - first_day).days
问题:使用python的requests模块抓取页面时出现乱码
解决:获取页面的content,使用str(r.content, 'utf-8')就可以解决了
方法:
方法一:
r = requests.get(url)
html = str(r.content, 'utf-8')
问题:注册时python后台如何发送邮件验证码
解决:自己搭建轻量级邮件服务器,通过smtp(简单的邮件传输协议)实现发送邮件功能
方法:
一、搭建邮件服务器
安装postfix(sudo apt-get install postfix),如果使用其它服务商的smtp就不需要安装了
二、发送邮件脚本
#!/usr/bin/python
# -*- coding: UTF-8 -*-
import smtplib from email.mime.text
import MIMEText from email.header
import Header
sender = 'from@runoob.com'
receivers = ['429240967@qq.com']
# 接收邮件,可设置为你的QQ邮箱或者其他邮箱
# 三个参数:第一个为文本内容,第二个 plain 设置文本格式,第三个 utf-8 设置编码
message = MIMEText('Python 邮件发送测试...', 'plain', 'utf-8')
message['From'] = Header("菜鸟教程", 'utf-8')
message['To'] = Header("测试", 'utf-8')
subject = 'Python SMTP 邮件测试'
message['Subject'] = Header(subject, 'utf-8')