gpt4 book ai didi

ruby - 使用 Ruby 1.9.3 和邮件 gem 进行字符编码

转载 作者:数据小太阳 更新时间:2023-10-29 06:48:30 24 4
gpt4 key购买 nike

我正在尝试使用 Ruby mail gem 解析电子邮件字符串,而且我在字符编码方面遇到了麻烦。获取以下电子邮件:

MIME-Version: 1.0
Sender: foobar@example.com
Received: by 10.142.239.17 with HTTP; Thu, 14 Jun 2012 06:00:18 -0700 (PDT)
Date: Thu, 14 Jun 2012 09:00:18 -0400
Delivered-To: foobar@gmail.com
X-Google-Sender-Auth: MxfFrMybNjBoBt4O4GwAn9cMsko
Message-ID: <CAGErOzF3FV5NvzN3zUpLGPok96SFzK18Z4HerzyYNALnzgMVaA@mail.gmail.com>
Subject: Re: [Lorem Ipsum] Foo updated the forum topic 'Reply by email test'
From: Foo Bar <foo@example.com>
To: Foo <c49964d167e08e7d4a1930e6565f23c258be19a0@foo.example.com>
Content-Type: text/plain; charset=ISO-8859-1
Content-Transfer-Encoding: quoted-printable

This email has accents:=A0R=E9sum=E9
>
> --------- Reply Above This Line ------------
>
> Email parsing with accents: R=E9sum=E9
>
> Click here to view this post in your browser

正确编码后的电子邮件正文应该是:

This reply has accents: Résumé
>
> --------- Reply Above This Line ------------
>
> Email parsing with accents: Résumé
>
> Click here to view this post in your browser

但是,实际上让重音符号通过时我遇到了麻烦。这是我尝试过的:

message = Mail.new(email_string)
body = message.body.decoded

这让我得到一个这样开头的字符串:

This reply has accents:\xA0R\xE9sum\xE9\r\n>\r\n> --------- Reply Above This Line ------------

最后,我试试这个:

body.encoding # => <Encoding:ASCII-8BIT>
body.encode("UTF-8") # => Encoding::UndefinedConversionError: "\xA0" from ASCII-8BIT to UTF-8

有没有人对如何处理这个问题有任何建议?我很确定它与电子邮件中的“charset=ISO-8859-1”设置有关,但我不确定如何使用它,或者是否有一种方法可以使用邮件 gem 轻松提取它。

最佳答案

玩了一下,发现了这个:

body.decoded.force_encoding("ISO-8859-1").encode("UTF-8") # => "This reply has accents: Résumé..."
message.parts.map { |part| part.decoded.force_encoding("ISO-8859-1").encode(part.charset) } # multi-part

您可以像这样从消息中提取字符集。

message.charset #=> for simple, non-multipart
message.parts.map { |part| part.charset } #=> for multipart, each part can have its own charset

小心非多部分,因为以下可能会导致麻烦:

body.charset #=> returns "US-ASCII" which is WRONG!
body.force_encoding(body.charset).encode("UTF-8") #=> Conversion error...

body.force_encoding(message.charset).encode("UTF-8") #=> Correct conversion :)

关于ruby - 使用 Ruby 1.9.3 和邮件 gem 进行字符编码,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11039522/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com