我正试图连接到我的谷歌表与gspread。下面是代码:
#IMPORT STANDARD LIBRARIES
import json
import os
#IMPORT THIRD PARTY LIBRARIES
import gspread
from oauth2client.client import SignedJwtAssertionCredentials
key_location = '/home/selecaotwo/Dropbox/Public/my.ENV/' + os.sep + 'sys.CREDENTIALS'
key_file_h = 'test-project-auth-a4f3c4bd20c4.json'
print key_location + os.sep + key_file_h
json_key = json.load(open(key_location + os.sep + key_file_h))
scope = ['https://spreadsheets.google.com/feeds']
credentials = SignedJwtAssertionCredentials(json_key['client_email'], json_key['private_key'], scope)
gc = gspread.authorize(credentials)
运行此代码会产生以下错误:
/home/selecaotwo/Dropbox/Public/my.ENV//sys.CREDENTIALS/test-project-auth-a4f3c4bd20c4.json
Traceback (most recent call last):
File "/home/selecaotwo/Desktop/gspread-test/gspread-test-001-codeRegist-0001.py", line 17, in <module>
gc = gspread.authorize(credentials)
File "/usr/local/lib/python2.7/site-packages/gspread/client.py", line 335, in authorize
client.login()
File "/usr/local/lib/python2.7/site-packages/gspread/client.py", line 98, in login
self.auth.refresh(http)
File "build/bdist.linux-x86_64/egg/oauth2client/client.py", line 598, in refresh
File "build/bdist.linux-x86_64/egg/oauth2client/client.py", line 769, in _refresh
File "build/bdist.linux-x86_64/egg/oauth2client/client.py", line 795, in _do_refresh_request
File "build/bdist.linux-x86_64/egg/oauth2client/client.py", line 1425, in _generate_refresh_request_body
File "build/bdist.linux-x86_64/egg/oauth2client/client.py", line 1554, in _generate_assertion
File "build/bdist.linux-x86_64/egg/oauth2client/crypt.py", line 162, in from_string
File "/usr/local/lib/python2.7/site-packages/OpenSSL/__init__.py", line 36, in <module>
from OpenSSL import crypto
ImportError: /usr/local/lib/python2.7/site-packages/OpenSSL/crypto.so: undefined symbol: PyUnicodeUCS2_Decode
[Finished in 0.1s with exit code 1]
[shell_cmd: python -u "/home/selecaotwo/Desktop/gspread-test/gspread-test-001-codeRegist-0001.py"]
[dir: /home/selecaotwo/Desktop/gspread-test]
[path: /usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin]
我在论坛上读到这可能是我的Ubuntu系统(14.04 LTS)和Python(2.7.9)之间的问题,但奇怪的是,当我用——enableencoding =usc2重新编译Python时,我在同一行上得到了相同的错误,而不是说"未定义的符号:PyUnicodeUCS2_Decode",它只是说"未定义的符号:PyUnicodeUCS4_Decode"。这使我相信问题可能是别的东西,我不确定如何继续。
我不确定这是否能解决问题。不输入json文件本身,您可以尝试像这样输入client_email和私钥吗?可以这样复制client_email。对于私钥,这样做:
key = u"-----BEGIN PRIVATE KEY-----nBLABLA_n-----END PRIVATE KEY-----n".encode("utf-8")
credentials = SignedJwtAssertionCredentials(client_email,key,scope)