"netrc" --- netrc 文件处理
**************************

**源代码:** Lib/netrc.py

======================================================================

"netrc" 类解析并封装了 Unix 的 **ftp** 程序和其他 FTP 客户端所使用的
netrc 文件格式。

class netrc.netrc([file])

   "netrc" 的实例或其子类的实例封装了来自 netrc 文件的数据。 如果有初
   始化参数，它将指明要解析的文件。 如果未给出参数，则位于用户的家目录
   的 ".netrc" 文件 -- 即 "os.path.expanduser()" 所确定的文件 -- 将会
   被读取。 在其他情况下，则将引发 "FileNotFoundError" 异常。 解析错误
   将引发 "NetrcParseError" 并附带诊断信息，包括文件名、行号以及终止令
   牌。

   如果在 POSIX 系统上未指明参数，则当 ".netrc" 文件中有密码时，如果文
   件归属或权限不安全（归属的用户不是运行进程的用户，或者可供任何其他
   用户读取或写入）将引发 "NetrcParseError"。 这实现了与 ftp 和其他使
   用 ".netrc" 的程序同等的安全行为。 这样的安全检查在不支持
   "os.getuid()" 的平台上将不可用。

   在 3.4 版本发生变更: 添加了 POSIX 权限检查。

   在 3.7 版本发生变更: 当未将 *file* 作为参数传入时会使用
   "os.path.expanduser()" 来查找 ".netrc" 文件的位置。

   在 3.10 版本发生变更: "netrc" 会在使用语言区域专属的编码格式之前先
   尝试 UTF-8 编码格式。 netrc 文件中的条目不再需要包括所有字段。 缺失
   字段的值默认将为空字符串。 所有的字段及其值现在可以包含任意字符，如
   空格和非 ASCII 字符。 如果登录名为 anonymous，它将不会触发安全检查
   。

exception netrc.NetrcParseError

   当源文本中出现语法错误时由 "netrc" 类所引发的异常。 该异常的实例提
   供了三个有用的属性:

   msg

      错误的解释性文本。

   filename

      源文件名。

   lineno

      发现错误所在的行号。


netrc 对象
==========

"netrc" 实例具有下列方法:

netrc.authenticators(host)

   针对 *host* 的身份验证者返回一个 3 元组 "(login, account,
   password)"。 如果 netrc 文件不包含针对给定主机的条目，则返回关联到
   'default' 条目的元组。 如果匹配的主机或默认条目均不可用，则返回
   "None"。

netrc.__repr__()

   将类数据以 netrc 文件的格式转储为一个字符串。 （这会丢弃注释并可能
   重排条目顺序。）

"netrc" 的实例具有一些公共实例变量:

netrc.hosts

   将主机名映射到 "(login, account, password)" 元组的字典。 如果存在
   'default' 条目，则会表示为使用该名称的伪主机。

netrc.macros

   将宏名称映射到字符串列表的字典。
