- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我正在尝试使用 Python 模块 MySQL-python 从运行 amazon linux 的 AWS EC2 实例连接到外部 MySQL 数据库。
这是我要运行的代码:
db=_mysql.connect(host="hostname",user="dbuser",passwd="dbpassword",db="database")
db.query("""SELECT id, field1 FROM test""")
r=db.store_result()
row = r.fetch_row()
print row
我已经用 pip 安装了 python 模块:
sudo pip install MySQL-python
当我运行脚本时,我收到以下错误消息:
Traceback (most recent call last):
File "script.py", line 2, in <module>
import _mysql
ImportError: No module named _mysql
当我研究这个时,我继续挖掘许多不适用于 amazon linux 的 Ubuntu/Debian linux 解决方案。
如何在 amazon linux 上修复此错误并运行脚本?
此外,来自任何有经验的 Linux 用户的观察/回答:在我尝试学习更多 Linux 并选择 AWS 时使用 Amazon Linux 有什么优势,还是使用 Ubuntu/Debian 镜像会更好?我不是一个经验丰富的 Linux 用户,可能从问题中可以看出。
更新
我发现在 amazon linux 服务器上安装包不成功。这是我尝试通过 pip 运行安装时的完整输出:
$ sudo pip install MySQL-Python
Collecting MySQL-Python
Using cached MySQL-python-1.2.5.zip
Installing collected packages: MySQL-Python
Running setup.py install for MySQL-Python ... error
Complete output from command /usr/bin/python2.7 -u -c "import setuptools, tokenize;__file__='/tmp/pip-build-B1IkvH/MySQL-Python/setup.py';exec(compile(getattr(tokenize, 'open', open)(__file__).read().replace('\r\n', '\n'), __file__, 'exec'))" install --record /tmp/pip-RNgtpa-record/install-record.txt --single-version-externally-managed --compile:
running install
running build
running build_py
creating build
creating build/lib.linux-x86_64-2.7
copying _mysql_exceptions.py -> build/lib.linux-x86_64-2.7
creating build/lib.linux-x86_64-2.7/MySQLdb
copying MySQLdb/__init__.py -> build/lib.linux-x86_64-2.7/MySQLdb
copying MySQLdb/converters.py -> build/lib.linux-x86_64-2.7/MySQLdb
copying MySQLdb/connections.py -> build/lib.linux-x86_64-2.7/MySQLdb
copying MySQLdb/cursors.py -> build/lib.linux-x86_64-2.7/MySQLdb
copying MySQLdb/release.py -> build/lib.linux-x86_64-2.7/MySQLdb
copying MySQLdb/times.py -> build/lib.linux-x86_64-2.7/MySQLdb
creating build/lib.linux-x86_64-2.7/MySQLdb/constants
copying MySQLdb/constants/__init__.py -> build/lib.linux-x86_64-2.7/MySQLdb/constants
copying MySQLdb/constants/CR.py -> build/lib.linux-x86_64-2.7/MySQLdb/constants
copying MySQLdb/constants/FIELD_TYPE.py -> build/lib.linux-x86_64-2.7/MySQLdb/constants
copying MySQLdb/constants/ER.py -> build/lib.linux-x86_64-2.7/MySQLdb/constants
copying MySQLdb/constants/FLAG.py -> build/lib.linux-x86_64-2.7/MySQLdb/constants
copying MySQLdb/constants/REFRESH.py -> build/lib.linux-x86_64-2.7/MySQLdb/constants
copying MySQLdb/constants/CLIENT.py -> build/lib.linux-x86_64-2.7/MySQLdb/constants
running build_ext
building '_mysql' extension
creating build/temp.linux-x86_64-2.7
gcc -pthread -fno-strict-aliasing -O2 -g -pipe -Wall -Wp,-D_FORTIFY_SOURCE=2 -fexceptions -fstack-protector --param=ssp-buffer-size=4 -m64 -mtune=generic -D_GNU_SOURCE -fPIC -fwrapv -DNDEBUG -O2 -g -pipe -Wall -Wp,-D_FORTIFY_SOURCE=2 -fexceptions -fstack-protector --param=ssp-buffer-size=4 -m64 -mtune=generic -D_GNU_SOURCE -fPIC -fwrapv -fPIC -Dversion_info=(1,2,5,'final',1) -D__version__=1.2.5 -I/usr/include/mysql55 -I/usr/include/python2.7 -c _mysql.c -o build/temp.linux-x86_64-2.7/_mysql.o -g -pipe -Wp,-D_FORTIFY_SOURCE=2 -fexceptions -fstack-protector --param=ssp-buffer-size=4 -m64 -D_GNU_SOURCE -D_FILE_OFFSET_BITS=64 -D_LARGEFILE_SOURCE -fno-strict-aliasing -fwrapv -fPIC -fPIC -g -static-libgcc -fno-omit-frame-pointer -fno-strict-aliasing -DMY_PTHREAD_FASTMUTEX=1
unable to execute 'gcc': No such file or directory
error: command 'gcc' failed with exit status 1
----------------------------------------
Command "/usr/bin/python2.7 -u -c "import setuptools, tokenize;__file__='/tmp/pip-build-B1IkvH/MySQL-Python/setup.py';exec(compile(getattr(tokenize, 'open', open)(__file__).read().replace('\r\n', '\n'), __file__, 'exec'))" install --record /tmp/pip-RNgtpa-record/install-record.txt --single-version-externally-managed --compile" failed with error code 1 in /tmp/pip-build-B1IkvH/MySQL-Python/
最佳答案
这只是一种解决方法,但在我无法轻易调用“sudo pip install”的情况下对我有用。
您(通常,并非总是)可以做什么:
如前所述,这并不漂亮;但如果没有更好的答案出现;你至少可以尝试一些东西......
关于python - 导入错误 : No module named _mysql,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39148410/
我正在运行 MySQLdb v1.2.3 并收到以下错误: LookupError: unknown encoding: utf8mb4 This answer建议将 MySQLdb 更新到版本 1.
我正在使用 Python 3,我想为 Python 安装 MySQLdb。我从这个 link 下载了 tar.gz 文件。 .然后提取并将 MySQLdb 文件夹复制到 Python 中的 Lib 文
我已经在运行 debian lenny 的服务器上部署了一个 django 项目。每次启动时都会弹出以下警告: /var/www/environment/XXX/src/django-pytest/d
我用python 3.7.10搭建了一个虚拟环境,通过安装 mysql 和 mysqlclient是mysql 8.0.28,mysqlclient 2.1.0。 运行 python manage.p
我的本地计算机上有一个运行sqlite3 db的Django博客。我想要的是 将sqlite3 db转换为mysql db 更改Django settings.py文件以提供MySQL数据库 在进行第
我用python 3.7.10搭建了一个虚拟环境,通过安装 mysql 和 mysqlclient是mysql 8.0.28,mysqlclient 2.1.0。 运行 python manage.p
我需要使用_mysql,但我不知道如何在没有错误的情况下获取我选择的所有输出。 db = sql.connect(host=host,user=user,passwd=pw,db=dbName) db
我是 Python 和 SQLAlchemy 的新手,我尝试使用它们一点,但每当我运行测试时,它都会出现以下错误: Traceback (most recent call last): File
PyCharm 无法导入模块 _mysql。 我之前做了什么: sudo apt-get install python-mysqldb sudo apt-get install mysql-serve
为什么MySQLdb模块中的_mysql是一个C文件?当模块尝试导入它时,出现导入错误。我该怎么办? 最佳答案 它是位于 Python MySQLdb 模块和 C libmysqlclient 库之间
好的,我以 root 身份登录到 MySQL 命令行客户端。然后我以 root 身份使用 MySQLdb 模块打开或运行一个 python 应用程序。当我使用 python (IDLE) 检查结果时,
我正在尝试使用 python 2.7 导入 MySQLdb,但出现以下错误。我是 Ubuntu 的新手,所以无法弄清楚哪里出了问题。 错误信息: import MySQLdb Traceback (m
我正在尝试使用 Python 模块 MySQL-python 从运行 amazon linux 的 AWS EC2 实例连接到外部 MySQL 数据库。 这是我要运行的代码: db=_mysql.co
我正在尝试初始化 Airflow mysql 数据库并收到以下错误。 ImportError: 1): dlopen(...venv/lib/python3.6/site-packages/_mysq
我正在尝试使用 MySQLdb,当我尝试导入它时出现以下错误。有什么想法吗?我目前在 aws 上使用 ubuntu 实例。 >>> import MySQLdb Traceback (mos
import MySQLdb 和 回溯: Traceback (most recent call last): File "D:\zjm_code\sphinx_test\a.py", line
我正在将我的应用程序从默认的 django 的 sqlitedb 迁移到 prod mariadb 数据库。有python3.3 + centos 7 + django 1.8 + apache环境。
我已经部署了一个 scrapy 项目,链接到一个使用 MySQLdb 的类(为了持久化并在运行蜘蛛之前获取一些数据)在 Python 2.7(本地机器)上,我没有问题。但是,在 Python 2.6(
我正在尝试将程序从 python 2 转换为 python 3。我在程序中设置的 MYSQL 数据库必须更新。我遇到了与 this one 非常相似的问题,但我不明白如何将我的对象从“连接”更改为“连
我刚刚发现我使用 _mysql 的方式导致了一个主要的 SQL 注入(inject)问题。 我当前的代码如下: db = _mysql.connect('', 'user', 'pass', 'db'
我是一名优秀的程序员,十分优秀!