sina使用郵箱密碼,qq使用16位受權嗎登錄html
#!/usr/bin/env python3 # -*- coding: utf-8 -*- from email.parser import Parser from email.header import decode_header from email.utils import parseaddr import poplib # 輸入郵件地址, 口令和POP3服務器地址: # email = input('Email: ') # password = input('Password: ') # pop3_server = input('POP3 server: ') # 新浪郵箱測試經過, 密碼使用登錄密碼 email = "18937905850@sina.cn" password = "password" pop3_server = "pop.sina.cn" # qq郵箱測試經過, 使用受權碼, 使用ssl # email = "343190282@qq.com" # password = "16位受權碼" # pop3_server = "pop.qq.com" def guess_charset(msg): charset = msg.get_charset() if charset is None: content_type = msg.get('Content-Type', '').lower() pos = content_type.find('charset=') if pos >= 0: charset = content_type[pos + 8:].strip() return charset def decode_str(s): value, charset = decode_header(s)[0] if charset: value = value.decode(charset) return value def print_info(msg, indent=0): if indent == 0: for header in ['From', 'To', 'Subject']: value = msg.get(header, '') if value: if header == 'Subject': value = decode_str(value) else: hdr, addr = parseaddr(value) name = decode_str(hdr) value = u'%s <%s>' % (name, addr) print('%s%s: %s' % (' ' * indent, header, value)) if (msg.is_multipart()): parts = msg.get_payload() for n, part in enumerate(parts): print('%spart %s' % (' ' * indent, n)) print('%s--------------------' % (' ' * indent)) print_info(part, indent + 1) else: content_type = msg.get_content_type() if content_type == 'text/plain' or content_type == 'text/html': content = msg.get_payload(decode=True) charset = guess_charset(msg) if charset: content = content.decode(charset) print('%sText: %s' % (' ' * indent, content + '...')) else: print('%sAttachment: %s' % (' ' * indent, content_type)) # 鏈接到POP3服務器: server = poplib.POP3(pop3_server) # qq須要使用ssl # server = poplib.POP3_SSL(pop3_server) # 能夠打開或關閉調試信息: server.set_debuglevel(1) # 可選:打印POP3服務器的歡迎文字: print(server.getwelcome().decode('utf-8')) # 身份認證: server.user(email) server.pass_(password) # stat()返回郵件數量和佔用空間: print('Messages: %s. Size: %s' % server.stat()) # list()返回全部郵件的編號: resp, mails, octets = server.list() # 能夠查看返回的列表相似[b'1 82923', b'2 2184', ...] print(mails) # 獲取最新一封郵件, 注意索引號從1開始: index = len(mails) resp, lines, octets = server.retr(index) # lines存儲了郵件的原始文本的每一行, # 能夠得到整個郵件的原始文本: msg_content = b'\r\n'.join(lines).decode('utf-8') # 稍後解析出郵件: msg = Parser().parsestr(msg_content) print_info(msg) # 能夠根據郵件索引號直接從服務器刪除郵件: # server.dele(index) # 關閉鏈接: server.quit()