python解析邮件的时候编码问题

import sys
import base64
import os
import re

s1 = '"=?UTF-8?B?56mG6Zi/5rWpKOWnnOW8iyk=?=" <ahao.mah@ffff.com>, "=?UTF-8?B?56mG6Zi/5rWpKOWnnOW8iyk=?=" <ahao.mah@ffff.com>'
s2 = '"=?UTF-8?B?56mG6Zi/5rWpKOWnnOW8iyk=?=" <ahao.mah@ffff.com>'
s3 = "=?GBK?B?wfXWvrvUKLPLu8Yp?="
s4 = "hello"

def encoded_words_to_text(encoded_words):
    aa = ""
    bb = ""

    if "UTF-8" in encoded_words or "GBK" in encoded_words:
        list02 = encoded_words.split()
        for k in list02:
            if "UTF-8" in k or "GBK" in k:
                encoded_word_regex = r'=\?{1}(.+)\?{1}([B|Q])\?{1}(.+)\?{1}='
                k = k.strip("\"")
                charset, encoding, encoded_text = re.match(encoded_word_regex, k).groups()
                if encoding is 'B':
                    byte_string = base64.b64decode(encoded_text)
                elif encoding is 'Q':
                    byte_string = quopri.decodestring(encoded_text)
                aa = byte_string.decode(charset)
            else:
                bb = k

        cc = aa+' '+bb
        return cc
    else:
        return encoded_words


list01 = s4.split(",")
for i in list01:
    ff=encoded_words_to_text(i)
    print ff

转载于:https://www.cnblogs.com/muahao/p/8288735.html

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值