Search
 
SCRIPT & CODE EXAMPLE
 

PYTHON

python reply to email

def send_mail_multi(headers, text, msgHtml="", orig=None):
    """
    """

    msg = MIMEMultipart('mixed')
    # Create message container - the correct MIME type is multipart/alternative.
    body = MIMEMultipart('alternative')

    for k,v in headers.items():
        if isinstance(v, list):
            v = ', '.join(v)
        msg.add_header(k, v)

    # Attach parts into message container.
    # According to RFC 2046, the last part of a multipart message, in this case
    # the HTML message, is best and preferred.
    if orig is not None:
        text, msgHtml2 = append_orig_text(text, msgHtml, orig, False)

        # Fix subject
        msg["Subject"] = "RE: "+orig["Subject"].replace("Re: ", "").replace("RE: ", "")
        msg['In-Reply-To'] = orig["Message-ID"]
        msg['References'] = orig["Message-ID"]#+orig["References"].strip()
        msg['Thread-Topic'] = orig["Thread-Topic"]
        msg['Thread-Index'] = orig["Thread-Index"]

    body.attach(MIMEText(text, 'plain'))
    if msgHtml != "": 
        body.attach(MIMEText(msgHtml2, 'html'))
    msg.attach(body)

    send_it(msg)


def append_orig_text(text, html, orig, google=False):
    """
    Append each part of the orig message into 2 new variables
    (html and text) and return them. Also, remove any 
    attachments. If google=True then the reply will be prefixed
    with ">". The last is not tested with html messages...
    """
    newhtml = ""
    newtext = ""

    for part in orig.walk():
        if (part.get('Content-Disposition')
            and part.get('Content-Disposition').startswith("attachment")):

            part.set_type("text/plain")
            part.set_payload("Attachment removed: %s (%s, %d bytes)"
                        %(part.get_filename(), 
                        part.get_content_type(), 
                        len(part.get_payload(decode=True))))
            del part["Content-Disposition"]
            del part["Content-Transfer-Encoding"]

        if part.get_content_type().startswith("text/plain"):
            newtext += "
"
            newtext += part.get_payload(decode=False)
            if google:
                newtext = newtext.replace("
","
> ")

        elif part.get_content_type().startswith("text/html"):
            newhtml += "
"
            newhtml += part.get_payload(decode=True).decode("utf-8")
            if google:
                newhtml = newhtml.replace("
", "
> ")

    if newhtml == "":
        newhtml = newtext.replace('
', '<br/>')

    return (text+'

'+newtext, html+'<br/>'+newhtml)
Comment

PREVIOUS NEXT
Code Example
Python :: python tex box 
Python :: count items in list python by loop 
Python :: Split a list based on a condition 
Python :: import one file into another python 
Python :: index start from 1 pandas 
Python :: syntax of calloc 
Python :: get fields in object python 
Python :: python write column csv 
Python :: create hasmap in python 
Python :: pandas sum group by 
Python :: append to an array in 1st place python 
Python :: python list append 
Python :: how to declare a lambda function in python 
Python :: python ceil method 
Python :: sorted function in python 3 
Python :: Find Factors of a Number Using Function 
Python :: Python script to SSH to server and run command 
Python :: python how to make a png 
Python :: import file in another path python 
Python :: create tuples in pandas 
Python :: converting list of arrays with same size to single array python 
Python :: adding numbers in python 
Python :: extract specific key values from python dictionary 
Python :: Python NumPy delete Function Syntax 
Python :: logging store info to different files 
Python :: python all but the last element 
Python :: python destructuring 
Python :: list programs in python 
Python :: __str__ returned non-string (type User) 
Python :: convert exception to string python 
ADD CONTENT
Topic
Content
Source link
Name
1+1 =