当我尝试导入passlib时,出现以下错误。在
ImportError: No module named passlib.apps
我试图通过以下命令安装它,他们声称它成功或已经存在,但我的程序仍然拒绝导入它:
pip安装密码库
sudo pip安装passlib
apt get安装python pip pip安装密码库
以下是我如何构建我的环境:
我导航到文档/45
我运行命令:source env/bin/activate
然后我运行pip install passlib,它告诉我:
已满足要求:./env/lib/python2.7/site-packages中的passlib
然后我打字/跑.py在
^{pr2}$这是我的密码 运行.py在
#!flask/bin/python
from app import app
app.run(debug=True)
这里是init.py
init__.py
import os
from flask import Flask
from flask.json import JSONEncoder
from flask_sqlalchemy import SQLAlchemy
from flask_login import LoginManager
from flask_mail import Mail
from flask_babel import Babel, lazy_gettext
from config import basedir, ADMINS, MAIL_SERVER, MAIL_PORT, MAIL_USERNAME, \
MAIL_PASSWORD
from .momentjs import momentjs
app = Flask(__name__)
app.config.from_object('config')
db = SQLAlchemy(app)
lm = LoginManager()
lm.init_app(app)
lm.login_view = 'login'
lm.login_message = lazy_gettext('Please log in to access this page.')
mail = Mail(app)
babel = Babel(app)
class CustomJSONEncoder(JSONEncoder):
"""This class adds support for lazy translation texts to Flask's
JSON encoder. This is necessary when flashing translated texts."""
def default(self, obj):
from speaklater import is_lazy_string
if is_lazy_string(obj):
try:
return unicode(obj) # python 2
except NameError:
return str(obj) # python 3
return super(CustomJSONEncoder, self).default(obj)
app.json_encoder = CustomJSONEncoder
if not app.debug and MAIL_SERVER != '':
import logging
from logging.handlers import SMTPHandler
credentials = None
if MAIL_USERNAME or MAIL_PASSWORD:
credentials = (MAIL_USERNAME, MAIL_PASSWORD)
mail_handler = SMTPHandler((MAIL_SERVER, MAIL_PORT),
'no-reply@' + MAIL_SERVER, ADMINS,
'microblog failure', credentials)
mail_handler.setLevel(logging.ERROR)
app.logger.addHandler(mail_handler)
if not app.debug and os.environ.get('HEROKU') is None:
import logging
from logging.handlers import RotatingFileHandler
file_handler = RotatingFileHandler('tmp/microblog.log', 'a',
1 * 1024 * 1024, 10)
file_handler.setLevel(logging.INFO)
file_handler.setFormatter(logging.Formatter(
'%(asctime)s %(levelname)s: %(message)s [in %(pathname)s:%(lineno)d]'))
app.logger.addHandler(file_handler)
app.logger.setLevel(logging.INFO)
app.logger.info('microblog startup')
if os.environ.get('HEROKU') is not None:
import logging
stream_handler = logging.StreamHandler()
app.logger.addHandler(stream_handler)
app.logger.setLevel(logging.INFO)
app.logger.info('microblog startup')
app.jinja_env.globals['momentjs'] = momentjs
from app import views, models
在模型.py在
from hashlib import md5
import re
from app import db
from app import app
from config import WHOOSH_ENABLED
from passlib.apps import custom_app_context as pwd_context
pip list和freeze输出都显示passlib 1.7.1
(env) jsnyder10@jsnyder10-VirtualBox:~/Documents/45$ pip list
DEPRECATION: The default format will switch to columns in the future. You can use --format=(legacy|columns) (or define a format=(legacy|columns) in your pip.conf under the [list] section) to disable this warning.
appdirs (1.4.3)
packaging (16.8)
passlib (1.7.1)
pip (9.0.1)
pyparsing (2.2.0)
setuptools (35.0.2)
six (1.10.0)
wheel (0.29.0)
(env) jsnyder10@jsnyder10-VirtualBox:~/Documents/45$ pip freeze
appdirs==1.4.3
packaging==16.8
passlib==1.7.1
pyparsing==2.2.0
six==1.10.0
不过,这对我有效,所以问题可能出在你的环境中。在
-我使用的是python2.7并安装了(通过pip)passlib-1.7.1。-
我没有意识到我是从flask/bin运行环境,所以运行以下命令修复了它
相关问题 更多 >
编程相关推荐