本文整理匯總了Python中email.generator.BytesGenerator.flatten方法的典型用法代碼示例。如果您正苦於以下問題:Python BytesGenerator.flatten方法的具體用法?Python BytesGenerator.flatten怎麽用?Python BytesGenerator.flatten使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類email.generator.BytesGenerator
的用法示例。
在下文中一共展示了BytesGenerator.flatten方法的12個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。
示例1: test_cte_type_7bit_transforms_8bit_cte
# 需要導入模塊: from email.generator import BytesGenerator [as 別名]
# 或者: from email.generator.BytesGenerator import flatten [as 別名]
def test_cte_type_7bit_transforms_8bit_cte(self):
source = textwrap.dedent("""\
From: [email protected]
To: Dinsdale
Subject: Nudge nudge, wink, wink
Mime-Version: 1.0
Content-Type: text/plain; charset="latin-1"
Content-Transfer-Encoding: 8bit
oh là là, know what I mean, know what I mean?
""").encode('latin1')
msg = message_from_bytes(source)
expected = textwrap.dedent("""\
From: [email protected]
To: Dinsdale
Subject: Nudge nudge, wink, wink
Mime-Version: 1.0
Content-Type: text/plain; charset="iso-8859-1"
Content-Transfer-Encoding: quoted-printable
oh l=E0 l=E0, know what I mean, know what I mean?
""").encode('ascii')
s = io.BytesIO()
g = BytesGenerator(s, policy=self.policy.clone(cte_type='7bit',
linesep='\n'))
g.flatten(msg)
self.assertEqual(s.getvalue(), expected)
示例2: createMessage
# 需要導入模塊: from email.generator import BytesGenerator [as 別名]
# 或者: from email.generator.BytesGenerator import flatten [as 別名]
def createMessage(self, entry=None):
""" Creates a message representing a given feed entry. """
logging.info("Creating message about: " + entry.title)
msg = email.mime.multipart.MIMEMultipart('alternative')
msg.set_charset(self.feed.encoding)
author = self.title()
try:
author = entry.author + " @ " + author
except AttributeError:
pass
msg['From'] = author
msg['Subject'] = entry.title
msg['To'] = config.username
date = time.time()
if hasattr(entry, 'updated_parsed') \
and entry.updated_parsed is not None:
date = entry.updated_parsed
elif hasattr(entry, 'published_parsed') \
and entry.published_parsed is not None:
date = entry.published_parsed
else:
logging.warning('Entry without a date: ' + entry.title)
if date is not None:
msg['Date'] = email.utils.format_datetime(
datetime.datetime.fromtimestamp(
time.mktime(date)))
headerName = 'X-Entry-Link'
msg[headerName] = email.header.Header(s=entry.link,
charset=self.feed.encoding)
try:
content = entry.content[0]['value']
except AttributeError:
try:
content = entry.summary
except AttributeError:
content = entry.description
html = content
text = html2text.html2text(html)
text = 'Retrieved from ' + entry.link + '\n' + text
html = html + \
'<p><a href="' + \
entry.link + \
'">Retrieved from ' + \
entry.link + \
'</a></p>'
part1 = email.mime.text.MIMEText(text, 'plain')
part2 = email.mime.text.MIMEText(html, 'html')
msg.attach(part1)
msg.attach(part2)
bytesIO = BytesIO()
bytesGenerator = BytesGenerator(bytesIO,
mangle_from_=True,
maxheaderlen=60)
bytesGenerator.flatten(msg)
text = bytesIO.getvalue()
return text
示例3: test_cte_type_7bit_handles_unknown_8bit
# 需要導入模塊: from email.generator import BytesGenerator [as 別名]
# 或者: from email.generator.BytesGenerator import flatten [as 別名]
def test_cte_type_7bit_handles_unknown_8bit(self):
source = ("Subject: Maintenant je vous présente mon "
"collègue\n\n").encode('utf-8')
expected = ('Subject: Maintenant je vous =?unknown-8bit?q?'
'pr=C3=A9sente_mon_coll=C3=A8gue?=\n\n').encode('ascii')
msg = message_from_bytes(source)
s = io.BytesIO()
g = BytesGenerator(s, policy=self.policy.clone(cte_type='7bit'))
g.flatten(msg)
self.assertEqual(s.getvalue(), expected)
示例4: mail_to_bytes
# 需要導入模塊: from email.generator import BytesGenerator [as 別名]
# 或者: from email.generator.BytesGenerator import flatten [as 別名]
def mail_to_bytes(mail):
"""Get bytes based on a mail.
Based on email.Message.as_bytes, but we reimplement it here because python
3.3 lacks it.
"""
fp = BytesIO()
g = BytesGenerator(fp, mangle_from_=False, policy=mail.policy)
g.flatten(mail, unixfrom=False)
return fp.getvalue()
示例5: write_message_to_file
# 需要導入模塊: from email.generator import BytesGenerator [as 別名]
# 或者: from email.generator.BytesGenerator import flatten [as 別名]
def write_message_to_file(message, filename):
"""
Write a message to the file with the
given filename.
"""
fp = open(os.path.join(args.dir, filename), "wb")
try:
generator = BytesGenerator(fp)
generator.flatten(message, linesep="\r\n")
finally:
fp.close()
示例6: as_bytes
# 需要導入模塊: from email.generator import BytesGenerator [as 別名]
# 或者: from email.generator.BytesGenerator import flatten [as 別名]
def as_bytes(self):
"""
converts the mail into a binary string
@return bytes
See `Message.as_bytes <https://docs.python.org/3/library/email.message.html#email.message.Message.as_bytes>`_
"""
fp = BytesIO()
g = BytesGenerator(fp, mangle_from_=True, maxheaderlen=60)
g.flatten(self)
return fp.getvalue()
示例7: main
# 需要導入模塊: from email.generator import BytesGenerator [as 別名]
# 或者: from email.generator.BytesGenerator import flatten [as 別名]
def main():
last_month = datetime.date.today().replace(day=1) - datetime.timedelta(days=1)
mails = get_mails()
if not mails:
print("No mails")
return
files = get_files(last_month)
if not files:
print("No files")
return
multipart = MIMEMultipart()
multipart['Subject'] = last_month.strftime("Temp: %Y-%m")
multipart['From'] = str(Address("Temperatura", addr_spec="[email protected]"))
multipart['To'] = ', '.join(str(m) for m in mails)
multipart.attach(MIMEText("""\
Witaj!
W załączeniu zapisy temperatury z ostatniego miesiąca.
--Temperatura"""))
for filepath in files:
if not filepath.is_file():
continue
ctype, encoding = mimetypes.guess_type(filepath.name)
if ctype is None or encoding is not None:
ctype = 'application/octet-stream'
maintype, subtype = ctype.split('/', 1)
with filepath.open('rb') as f:
attachment = MIMEBase(maintype, subtype)
attachment.set_payload(f.read())
encoders.encode_base64(attachment)
attachment.add_header('Content-Disposition', 'attachment', filename=filepath.name)
multipart.attach(attachment)
with open(datetime.datetime.now().strftime('email-%Y-%m-%d-%H-%M-%s.msg'), 'wb') as f:
fp = BytesIO()
g = BytesGenerator(fp, mangle_from_=True, maxheaderlen=60)
g.flatten(multipart)
text = fp.getvalue()
f.write(text)
try:
with smtplib.SMTP_SSL('poczta.o2.pl', port=465) as s:
s.login('[email protected]', 'shtiSlaidd')
s.send_message(multipart)
except smtplib.SMTPResponseException as e:
if e.smtp_code == 250 and e.smtp_error == b'Ok':
pass # o2.pl bug. Returns 250 Ok instead of 221
else:
raise
示例8: select
# 需要導入模塊: from email.generator import BytesGenerator [as 別名]
# 或者: from email.generator.BytesGenerator import flatten [as 別名]
def select(self, mailbox='INBOX.' + config.mailbox):
""" Selects given mailbox or mailbox given in config gile. """
logging.info("Selecting mailbox: " + mailbox)
mbox = mailbox
if mbox[0] != '"':
mbox = '"' + mbox + '"'
status, message = self.imap.select(mbox)
if status == 'NO': # there's no such mailbox, let's create one
self.imap.select()
status, message = self.imap.create(mbox)
if status != "OK":
logging.error("Could not create mailbox: " + str(mbox))
self.imap.subscribe(mbox)
status, message = self.imap.select(mbox)
if status != "OK":
logging.error("Could not select mailbox: " + str(mbox))
if mbox in ['"INBOX.testyarss2imap"', '"INBOX.' + config.mailbox + '"']:
# The default yarss2imap mailbox was just created
# Let's populate it with a README message.
logging.info("Creating README message")
msg = email.mime.multipart.MIMEMultipart('alternative')
msg.set_charset("utf-8")
msg['From'] = "[email protected]"
msg['Subject'] = "Welcome to yarss2imap. README please."
msg['To'] = config.username
msg['Date'] = email.utils.format_datetime(
datetime.datetime.fromtimestamp(
time.time()))
f = open('README.md','r')
content = f.read()
f.close()
part = email.mime.text.MIMEText(content, 'plain')
msg.attach(part)
bytesIO = BytesIO()
bytesGenerator = BytesGenerator(bytesIO,
mangle_from_=True,
maxheaderlen=60)
bytesGenerator.flatten(msg)
text = bytesIO.getvalue()
status, error = self.imap.append(
mbox,
'',
imaplib.Time2Internaldate(time.time()),
text)
if status != 'OK':
logging.error('Could not append README message: ' + error)
self.imap.select(mbox)
return status
示例9: as_bytes
# 需要導入模塊: from email.generator import BytesGenerator [as 別名]
# 或者: from email.generator.BytesGenerator import flatten [as 別名]
def as_bytes(self, unixfrom=False, policy=None):
"""Return the entire formatted message as a bytes object.
Optional 'unixfrom', when true, means include the Unix From_ envelope
header. 'policy' is passed to the BytesGenerator instance used to
serialize the message; if not specified the policy associated with
the message instance is used.
"""
from email.generator import BytesGenerator
policy = self.policy if policy is None else policy
fp = BytesIO()
g = BytesGenerator(fp, mangle_from_=False, policy=policy)
g.flatten(self, unixfrom=unixfrom)
return fp.getvalue()
示例10: test_smtputf8_policy
# 需要導入模塊: from email.generator import BytesGenerator [as 別名]
# 或者: from email.generator.BytesGenerator import flatten [as 別名]
def test_smtputf8_policy(self):
msg = EmailMessage()
msg['From'] = "Páolo <fő[email protected]>"
msg['To'] = 'Dinsdale'
msg['Subject'] = 'Nudge nudge, wink, wink \u1F609'
msg.set_content("oh là là, know what I mean, know what I mean?")
expected = textwrap.dedent("""\
From: Páolo <fő[email protected]>
To: Dinsdale
Subject: Nudge nudge, wink, wink \u1F609
Content-Type: text/plain; charset="utf-8"
Content-Transfer-Encoding: 8bit
MIME-Version: 1.0
oh là là, know what I mean, know what I mean?
""").encode('utf-8').replace(b'\n', b'\r\n')
s = io.BytesIO()
g = BytesGenerator(s, policy=policy.SMTPUTF8)
g.flatten(msg)
self.assertEqual(s.getvalue(), expected)
示例11: encode_multipart_message
# 需要導入模塊: from email.generator import BytesGenerator [as 別名]
# 或者: from email.generator.BytesGenerator import flatten [as 別名]
def encode_multipart_message(message):
# The message must be multipart.
assert message.is_multipart()
# The body length cannot yet be known.
assert "Content-Length" not in message
# So line-endings can be fixed-up later on, component payloads must have
# no Content-Length and their Content-Transfer-Encoding must be base64
# (and not quoted-printable, which Django doesn't appear to understand).
for part in message.get_payload():
assert "Content-Length" not in part
assert part["Content-Transfer-Encoding"] == "base64"
# Flatten the message without headers.
buf = BytesIO()
generator = BytesGenerator(buf, False) # Don't mangle "^From".
generator._write_headers = lambda self: None # Ignore.
generator.flatten(message)
# Ensure the body has CRLF-delimited lines. See
# http://bugs.python.org/issue1349106.
body = b"\r\n".join(buf.getvalue().splitlines())
# Only now is it safe to set the content length.
message.add_header("Content-Length", "%d" % len(body))
return message.items(), body
示例12: msg_as_input
# 需要導入模塊: from email.generator import BytesGenerator [as 別名]
# 或者: from email.generator.BytesGenerator import flatten [as 別名]
def msg_as_input(self, msg):
m = message_from_bytes(msg, policy=policy.SMTP)
b = io.BytesIO()
g = BytesGenerator(b)
g.flatten(m)
self.assertEqual(b.getvalue(), msg)