使用 configparser 传递 API 凭据时遇到问题

Trouble using configparser to pass API credentials

我有一个 config.ini 文件,看起来像这样

[REDDIT]
client_id = 'myclientid23jd934g'
client_secret = 'myclientsecretjf30gj5g'
password = 'mypassword'
user_agent = 'myuseragent'
username = 'myusername'

当我尝试像这样使用 reddit 的 API praw 时:

import configparser
import praw

class redditImageScraper:
    def __init__(self, sub, limit):
        config = configparser.ConfigParser()
        config.read('config.ini')
        self.sub = sub
        self.limit = limit
        self.reddit = praw.Reddit(client_id=config.get('REDDIT','client_id'),
                                  client_secret=config.get('REDDIT','client_secret'),
                                  password=config.get('REDDIT','password'),
                                  user_agent=config.get('REDDIT','user_agent'),
                                  username=config.get('REDDIT','username'))


    def get_content(self):
        submissions = self.reddit.subreddit(self.sub).hot(limit=self.limit)
        for submission in submissions:
            print(submission.id)

def main():
    scraper = redditImageScraper('aww', 25)
    scraper.get_content()

if __name__ == '__main__':
    main()

我得到这个回溯

Traceback (most recent call last):
  File "config.py", line 30, in <module>
    main()
  File "config.py", line 27, in main
    scraper.get_content()
  File "config.py", line 22, in get_content
    for submission in submissions:
  File "C:\Users\Evan\Anaconda3\lib\site-packages\praw\models\listing\generator.py", line 61, in __next__
    self._next_batch()
  File "C:\Users\Evan\Anaconda3\lib\site-packages\praw\models\listing\generator.py", line 71, in _next_batch
    self._listing = self._reddit.get(self.url, params=self.params)
  File "C:\Users\Evan\Anaconda3\lib\site-packages\praw\reddit.py", line 454, in get
    data = self.request("GET", path, params=params)
  File "C:\Users\Evan\Anaconda3\lib\site-packages\praw\reddit.py", line 627, in request
    method, path, data=data, files=files, params=params
  File "C:\Users\Evan\Anaconda3\lib\site-packages\prawcore\sessions.py", line 185, in request
    params=params, url=url)
  File "C:\Users\Evan\Anaconda3\lib\site-packages\prawcore\sessions.py", line 116, in _request_with_retries
    data, files, json, method, params, retries, url)
  File "C:\Users\Evan\Anaconda3\lib\site-packages\prawcore\sessions.py", line 101, in _make_request
    params=params)
  File "C:\Users\Evan\Anaconda3\lib\site-packages\prawcore\rate_limit.py", line 35, in call
    kwargs['headers'] = set_header_callback()
  File "C:\Users\Evan\Anaconda3\lib\site-packages\prawcore\sessions.py", line 145, in _set_header_callback
    self._authorizer.refresh()
  File "C:\Users\Evan\Anaconda3\lib\site-packages\prawcore\auth.py", line 328, in refresh
    password=self._password)
  File "C:\Users\Evan\Anaconda3\lib\site-packages\prawcore\auth.py", line 138, in _request_token
    response = self._authenticator._post(url, **data)
  File "C:\Users\Evan\Anaconda3\lib\site-packages\prawcore\auth.py", line 31, in _post
    raise ResponseException(response)
prawcore.exceptions.ResponseException: received 401 HTTP response

然而,当我手动插入凭据时,我的代码 运行 完全符合预期。另外,如果我 运行 行

print(config.get('REDDIT', 'client_id'))

我得到了预期的输出 'myclientid23jd934g'

有什么原因导致 praw 不允许我使用 configparser 传递我的凭据吗?

仔细检查您对 praw.Reddit 的输入是什么:

kwargs = dict(client_id=config.get('REDDIT','client_id'),
              client_secret=config.get('REDDIT','client_secret'),
              password=config.get('REDDIT','password'),
              user_agent=config.get('REDDIT','user_agent'),
              username=config.get('REDDIT','username'))) 
print(kwargs)
praw.Reddit(**kwargs)

您在这里的配置过于复杂了 — PRAW 会为您解决这个问题。

如果将 config.ini 重命名为 praw.ini,则可以将整个初始化替换为

self.reddit = praw.Reddit('REDDIT')

这是因为 PRAW 会查找 praw.ini 文件并为您解析。如果您想给该部分一个更具描述性的名称,请确保在 praw.ini 以及传递给 Reddit 的单个参数(指定要使用的文件部分)中对其进行更新。

https://praw.readthedocs.io/en/latest/getting_started/configuration/prawini.html

如本页所述,用户名和密码等值不应该用引号引起来。例如,

password=mypassword

是正确的,但是

password="mypassword"

不正确。