"InvalidSchema" при попытке создать файл с github3.py
Используя github3.py 1.0.0a4, я пытаюсь создать простую "серверную" программу, которая создает, обновляет, удаляет и выбирает файлы. Тем не менее, моя программа вызывает "InvalidSchema" при попытке создать файл. Зачем? Я проверил мою программу с документацией...
Код:
from github3 import login
from github3.repos.repo import Repository
import sys, time
print sys.argv
if len(sys.argv) != 5:
print 'Usage: server.exe username=... password=... [[-create -delete -update -fetch] file] [repo=server]'
sys.exit()
try:
un, pw, mode, f = sys.argv[1].split('='), sys.argv[2].split('='), sys.argv[3], sys.argv[4]
me = login(un, pw)
except:
print 'Usage: server.exe username=... password=... [[-create -delete -update -fetch] file] [repo=server]'
sys.exit()
try:
repo = sys.argv[5]
except IndexError:
repo = 'server'
repo = Repository({'name':repo}, session=me)
if mode == '-create':
f = open(f)
name = f.name
data = f.read()
repo.create_file(name, 'Create '+time.asctime(), data.encode('utf-8'))
if mode == '-delete':
f = open(f)
repo.contents(f.name).delete('Delete '+time.asctime(), data.encode('utf-8'))
if mode == '-update':
f = open(f)
name = f.name
data = f.read()
repo.contents(name).update('Update '+time.asctime(), data.encode('utf-8'))
if mode == '-fetch':
with open(f, mode='w') as f:
f.write(repo.contents(f.name))
Результат при запуске в командной строке:
C:\Python27>python server.py username=... password=... -create pytest.py
['server.py', 'username=...', 'password=...', '-create', 'pytest.py']
Traceback (most recent call last):
File "server.py", line 30, in <module>
repo.create_file(name, 'Create '+time.asctime(), data.encode('utf-8'))
File "C:\Python27\lib\site-packages\github3\decorators.py", line 33, in auth_wrapper
return func(self, *args, **kwargs)
File "C:\Python27\lib\site-packages\github3\repos\repo.py", line 745, in create_file
json = self._json(self._put(url, data=dumps(data)), 201)
File "C:\Python27\lib\site-packages\github3\models.py", line 199, in _put
return self.session.put(url, **kwargs)
File "C:\Python27\lib\site-packages\requests\sessions.py", line 521, in put
return self.request('PUT', url, data=data, **kwargs)
File "C:\Python27\lib\site-packages\github3\session.py", line 88, in request
response = super(GitHubSession, self).request(*args, **kwargs)
File "C:\Python27\lib\site-packages\requests\sessions.py", line 468, in request
resp = self.send(prep, **send_kwargs)
File "C:\Python27\lib\site-packages\requests\sessions.py", line 570, in send
adapter = self.get_adapter(url=request.url)
File "C:\Python27\lib\site-packages\requests\sessions.py", line 644, in get_adapter
raise InvalidSchema("No connection adapters were found for '%s'" % url)
requests.exceptions.InvalidSchema: No connection adapters were found for ':///contents/pytest.py
2 ответа
Решение
На этой линии:
un, pw, mode, f = sys.argv[1].split('='), sys.argv[2].split('='), sys.argv[3], sys.argv[4]
вы назначаете un
а также pw
в виде списков, когда вы используете их, как строки. Вам нужно найти второй пункт списков, созданных из .split()
: замена строки на
un, pw, mode, f = sys.argv[1].split('=')[1], sys.argv[2].split('=')[1], sys.argv[3], sys.argv[4]
работал на меня.
un
а также pw
это списки, а не строки. использование un = sys.argv[1].split('=')[1]
или что-то типа того.
Отредактированный код:
from github3 import login
from github3.repos.repo import Repository
import sys, time
if len(sys.argv) != 5:
print 'Usage: server.exe username=... password=... [[-create -delete -update -fetch] file] [repo=server]'
sys.exit()
try:
un, pw, mode, f = sys.argv[1].split('=')[1], sys.argv[2].split('=')[1], sys.argv[3], sys.argv[4]
me = login(un, pw)
except:
print 'Usage: server.exe username=... password=... [[-create -delete -update -fetch] file] [repo=server]'
sys.exit()
try:
repo = sys.argv[5]
except IndexError:
repo = 'server'
repo = me.repository(un, repo)
if mode == '-create':
f = open(f)
name = f.name
data = f.read()
repo.create_file(name, 'Create '+time.asctime(), data.encode('utf-8'))
if mode == '-delete':
f = open(f)
repo.file_contents(f.name).delete('Delete '+time.asctime())
if mode == '-update':
f = open(f)
name = f.name
data = f.read()
repo.file_contents(name).update('Update '+time.asctime(), f.read().encode('utf-8'))
if mode == '-fetch':
with open(f, mode='w') as f:
f.write(repo.file_contents(f.name).decoded)
(Некоторые другие ошибки, такие как удаление, были исправлены.)