Я пытаюсь открыть базу данных mysql в windows 10 с помощью anaconda (python 3.7 64 bit) и пакета pymysql.
Из командной строки Windows я делаю следующее:
import pymysql
db = pymysql.connect(host='localhost', user='tester', passwd='xxxx', port=3306, db='mydb')
Имя пользователя, пароль и порт верны; хост должен быть localhost (я получаю ту же ошибку, если я передаю 127.0.0.1); но я получаю следующую ошибку, которая в конце утверждает, что не может найти пакет ffi:
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
File "C:\programs\Anaconda3\lib\site-packages\pymysql\__init__.py", line 94, in Connect
return Connection(*args, **kwargs)
File "C:\programs\Anaconda3\lib\site-packages\pymysql\connections.py", line 327, in __init__
self.connect()
File "C:\programs\Anaconda3\lib\site-packages\pymysql\connections.py", line 598, in connect
self._request_authentication()
File "C:\programs\Anaconda3\lib\site-packages\pymysql\connections.py", line 873, in _request_authentication
auth_packet = _auth.caching_sha2_password_auth(self, auth_packet)
File "C:\programs\Anaconda3\lib\site-packages\pymysql\_auth.py", line 252, in caching_sha2_password_auth
data = sha2_rsa_encrypt(conn.password, conn.salt, conn.server_public_key)
File "C:\programs\Anaconda3\lib\site-packages\pymysql\_auth.py", line 132, in sha2_rsa_encrypt
rsa_key = serialization.load_pem_public_key(public_key, default_backend())
File "C:\programs\Anaconda3\lib\site-packages\cryptography\hazmat\backends\__init__.py", line 15, in default_backend
from cryptography.hazmat.backends.openssl.backend import backend
File "C:\programs\Anaconda3\lib\site-packages\cryptography\hazmat\backends\openssl\__init__.py", line 7, in <module>
from cryptography.hazmat.backends.openssl.backend import backend
File "C:\programs\Anaconda3\lib\site-packages\cryptography\hazmat\backends\openssl\backend.py", line 53, in <module>
from cryptography.hazmat.bindings.openssl import binding
File "C:\programs\Anaconda3\lib\site-packages\cryptography\hazmat\bindings\openssl\binding.py", line 13, in <module>
from cryptography.hazmat.bindings._openssl import ffi, lib
ImportError: DLL load failed: The specified module could not be found.
Я видел, что навигатор conda (ни pip) не видит пакет ffi из своих стандартных каналов.
Я уже попробовал это предложение (добавив канал conda-forge):
Конда Конфиг - дополнительные каналы Конда-Фордж
Конда установить libffi
но Конда всегда остается в «решающей среде» и не дает ответов в разумные сроки.
Что я должен сделать, чтобы установить ffi и иметь возможность подключения к БД? Я первый в мире звоню mysql из python / Anaconda на windows? Я полагаю, что должно быть решение.
Спасибо, Марко