- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
这将是我一生中第二次发布几乎完全相同的事情。这次和上次相差了大约9个月,学习过程非常困难,而且在过去的9个月里我从来没有遇到过这个问题,并且在整个时间段内经常完美地使用MySQLdb。我认识到类似的问题已经被问过很多次了。我已阅读回复并执行了建议的修复。到目前为止,我仍然无法得出一个成功的结论,这就是我提出问题的原因。
仅描述我的环境:我正在使用 Google App Engine 启动器在本地 Google App Engine 上运行 Django 应用程序。我使用的是 Mac OS X El Capitan。
当这些应用程序部署在 Google App Engine 上时,它们可以按预期完美运行。但是,在本地运行时,我会在尝试运行应用程序时始终收到 ImportError。
让我列出一些我已经检查和/或尝试解决问题的内容:
-安装mysql
-安装了mysql-python
-将 MySQLdb 添加到 app.yaml 中的“库”部分
-在运行时检查 PYTHONPATH 以确认正确的目录已添加到路径中。
-在导入之前添加路径作为虚拟检查
-更新了 Google App Engine SDK
我还做过更多,但现在几乎想不起来了。在运行时检查路径时,我可以清楚地看到MySQLdb所在的google_appengine SDK目录的路径如下:
/Applications/GoogleAppEngineLauncher.app/Contents/Resources/GoogleAppEngine-default.bundle/Contents/Resources/google_appengine/lib/MySQLdb-1.2.5
这不是我应该看到的吗?我应该指出其他东西吗?我还指出了安装了其他 python 软件包的其他目录(例如/Library/Python/2.7/site-packages/)。我缺少什么?我知道我正在做一些愚蠢的事情,但我对此感到满意。我只是不想再浪费自己的时间去解决这样一个愚蠢的问题。我每天在其他项目中都使用MySQL,从来没有遇到过这样的问题。我现在真的不知道那是什么。
如果我可以添加更多有用的信息,请告诉我,我会很乐意帮忙。我将把我的一些文件放在下面,希望它们有用。
app.yaml:
application: *omitted*
version: 1
runtime: python27
api_version: 1
threadsafe: true
env_variables:
DJANGO_SETTINGS_MODULE: 'Freya.settings'
handlers:
- url: /favicon\.ico
static_files: static/images/favicon.ico
upload: static/images/favicon\.ico
- url: /static
static_dir: static
application_readable: true
- url: /.*
script: main.app
libraries:
- name: django
version: "latest"
- name: MySQLdb
version: "latest"
main.py:
from google.appengine.ext.webapp import util
import django.dispatch.dispatcher
import django.core.handlers.wsgi
from django.conf import settings
import django.core.signals
import django.db
import os
settings._target = None
app = django.core.handlers.wsgi.WSGIHandler()
def main():
util.run_wsgi_app(app)
if __name__ == '__main__':
main()
settings.py(数据库位):
'default': {
'ENGINE': 'django.db.backends.mysql',
'HOST': '*omitted*',
'NAME': '*omitted*',
'USER': '*omitted*',
}
非常感谢任何帮助。
这是我在 settings.py 中尝试过的示例:
import imp
import sys
import os
print('Checking')
try:
imp.find_module('MySQLdb')
found = True
except ImportError:
found = False
print('Found: ' + str(found))
import MySQLdb
print('Import success')
这样做,当我寻找“Found: false”时,我没有找到它。我发现 'Found: true' 这应该真正告诉我找到 MySQLdb 模块没有任何问题。但是,当到达 import MySQLdb
行时,程序崩溃,并显示 ImportError: No module named MySQLdb
和 print('Import success')
行> 从未达到
发生什么事了?
编辑:我现在将尝试在我的 Linux 分区上执行此操作,尽管我认为我在那里所做的任何事情都不会帮助我弄清楚在 Mac OS 上要做什么
最佳答案
经过几个小时的研究,我终于发现了根本问题。从 MySQLdb 正常工作到 MySQLdb 停止正常工作之间发生的唯一重大变化是在我将 OS X 升级到 El Capitan 时。
运行:
otool -L/Library/Python/2.7/site-packages/_mysql.so
透露_mysql.so
正在/usr/lib
目录中搜索libmysqlclient.18.dylib
,而实际上它位于/usr/local/lib
目录。作为一种快速修复,我通过运行以下命令创建了一个符号链接(symbolic link)(顺便说一句,全部都在一行上):
sudo ln -s/usr/local/mysql/lib/libmysqlclient.18.dylib/usr/local/lib/libmysqlclient.18.dylib
由于 El Capitan 实现了 Apple 的“无根”模式,并且当前用户(我)无法写入 /usr/lib
,因此在 /usr/local/中创建符号链接(symbolic link)lib
对于 Mac 用户来说已经足够了,而且可能更好。
执行这些步骤后,MySQLdb 能够正确加载;我的应用程序很长一段时间以来第一次成功初始化并运行。
关于python - 配置不正确 : Error loading MySQLdb module: No module named MySQLdb -- Django 1. 4 & Google App Engine,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/38926708/
我有一堆字符串,其中包含以姓氏,名字格式命名的名称列表,并用逗号分隔,如下所示: names 序列化字符串中的“first name last name”,我们在Stack Overflow上找到一个
在尝试合并多个数据框时,我得到了一些非常奇怪的东西。帮助! 我需要通过“RID”和“VISCODE”列合并一堆数据框。这是它的外观示例: d1 = data.frame(ID = sample(9,
让我们尽可能简单地做第一个例子。 我想知道如何应用这个宏;像这里适用于例如printf("%s",macro(arg)); #include #include #include #define
以下2个bean声明之间有什么区别吗? @Bean(name = "bean1") public A getA() { return new A(); } @Bean @Quali
if(c.get_name(&name) && name && !strcmp(name, contName)) 谁能告诉我这行代码在 C++ 中的含义 最佳答案 如果 c 有一个名字并且它等于 co
我是 Rails 的初学者,在改进我的搜索查询时遇到了一些问题: 在我调用的 Controller 中: def index if params[:search] @persons = Pers
谁能帮我解决这段代码的最后一部分的编译错误它的说法创建构造函数请帮助 public class Officer { public static void main(String args[]
关闭。这个问题需要details or clarity .它目前不接受答案。 想改进这个问题吗? 通过 editing this post 添加细节并澄清问题. 关闭 8 年前。 Improve t
我创建了一个 Web 应用程序,它具有使用 JSF 技术的 createBook.xhtml 并且它使用托管 Bean。在此页面中,用户必须在输入字段中填写所需信息,然后点击提交按钮。然后应使用 do
嘿,我正在尝试弄清楚如何将在 mySQL 中工作的语句转换为 PostgreSQL 并且很好奇是否有人知道解决方案。 这是在 mySQL 中有效的语句: def self.by_name(keywor
如果我要创建所有类型的类型,而不是使用字符串和原始类型,那么最大的缺点是什么? 通常它看起来像: String name = person.getName(); int age = person.ge
我正在尝试从以下内容中提取郊区名称: 12 street name, suburb name, CTG 1234 在 PHP 中使用正则表达式。 街道和郊区名称都可以是任意数量的单词长度。 CTG 是
我有一个呈现个人详细信息组件的父组件,并且正在注入(inject)父组件的验证器范围。如果我使用 v-validate 指令和 this.$validator.validateAll() 或 this
现在,据我了解,name[] 声明中的 extern 告诉编译器它的定义在其他地方(在我的程序中,我定义了它低于我使用它的部分)。但是为什么 strlen() 和 sizeof 会有不同的结果?str
我一直在解决一个问题: "Design a program that asks the user for a series of names (in no particular order). Aft
我的 XML 如下所示: 我想使用 JAXB 来阅读该内容。 我知道我能做到 @XmlRootElement(name="thing") public class Thing{
对于字符串 name[],我们可以使用 strlen(name)+1 和 sizeof(name) 互换 在我们的代码中没有经过深思熟虑?他们不一样吗?我检查了一下,发现两者的返回类型都是相同的,si
我正在尝试从以下内容中提取郊区名称: 12 street name, suburb name, CTG 1234 在 PHP 中使用正则表达式。 街道和郊区名称的长度可以是任意数量。 CTG 是 st
关闭。这个问题需要details or clarity .它目前不接受答案。 想改进这个问题吗? 通过 editing this post 添加细节并澄清问题. 关闭 8 年前。 Improve t
bash 手册列出了 for 的语法。复合语句为for name [ [ in [ word ... ] ] ; ] do list ; done这意味着 do 之前的分号如果 in 是可选的子句省略
我是一名优秀的程序员,十分优秀!