- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在用 python 2.7 开发我自己的模块。它位于 ~/Development/.../myModule
而不是 /usr/lib/python2.7/dist-packages
或 /usr/lib/python2.7/site-packages
.内部结构为:
/project-root-dir
/server
__init__.py
service.py
http.py
/client
__init__.py
client.py
client/client.py
包括
PyCachedClient
类(class)。我遇到了导入问题:
project-root-dir$ python
Python 2.7.2+ (default, Jul 20 2012, 22:12:53)
[GCC 4.6.1] on linux2
Type "help", "copyright", "credits" or "license" for more information.
>>> from server import http
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
File "server/http.py", line 9, in <module>
from client import PyCachedClient
ImportError: cannot import name PyCachedClient
project-root-dir
,因此当 server.http 尝试包含 client.PyCachedClient 时,它尝试从相对路径加载它并失败。我的问题是 - 我应该如何以良好的 Pythonic 方式设置所有路径/设置?我知道我可以跑
export PYTHONPATH=...
每次我打开控制台并尝试运行我的服务器时都在 shell 中,但我想这不是最好的方法。如果我的模块是通过 PyPi(或类似的东西)安装的,我会将它安装在
/usr/lib/python...
中路径,它会自动加载。
最佳答案
我的 Python 开发工作流程
这是开发 Python 包的基本过程,其中包含了我认为是社区中的最佳实践。这是基本的——如果你真的很认真地开发 Python 包,那么它还有更多的东西,每个人都有自己的偏好,但它应该作为一个模板来开始,然后更多地了解所涉及的部分。基本步骤是:
virtualenv
用于隔离 setuptools
用于创建可安装包和管理依赖项 python setup.py develop
在开发模式下安装该软件包 virtualenv
获得一个隔离的环境来开发你的包。在开发过程中,你需要安装、升级、降级和卸载你的包的依赖项,你不希望
site-packages
site-packages
影响您的开发环境 site-packages
不好,因为您在那里安装的任何包都可用于您安装的所有使用系统 Python 的 Python 应用程序,即使您的小项目只需要该依赖项。它刚刚安装在一个新版本中,该版本覆盖了系统范围内的版本
site-packages
,并且与依赖它的 ${important_app} 不兼容。你明白了。
site-packages
影响你的开发环境是不好的,因为也许你的项目依赖于你已经在系统 Python 中获得的模块
site-packages
.因此,您忘记正确声明您的项目依赖于该模块,但一切正常,因为它始终存在于您的本地开发框中。直到您发布您的软件包并且人们尝试安装它,或将其推送到生产环境,等等......在干净的环境中开发迫使您正确声明您的依赖项。
virtualenv
通过使用
easy_install
将其安装到系统范围的 Python 来打包或
pip
:
sudo pip install virtualenv
cd ~/pyprojects
virtualenv --no-site-packages foobar-env
~/pyprojects/foobar-env
,这是您的 virtualenv。
cd
进入它和
source
bin/activate script
:
~/pyprojects $ cd foobar-env/
~/pyprojects/foobar-env $ . bin/activate
(foobar-env) ~/pyprojects/foobar-env $
.
,这是
source
的简写 shell 命令。还要注意提示是如何变化的:
(foobar-env)
意味着您在激活的 virtualenv 内部(并且始终需要隔离才能工作)。因此,每次打开新的终端选项卡或 SSH session 等时,请激活您的 env。
python
在那个激活的环境中,它实际上会使用
~/pyprojects/foobar-env/bin/python
作为口译员,拥有自己的
site-packages
和隔离模块搜索路径。
setuptools
包装带有
setup.py
正确声明包的元数据和依赖项。您可以按照
setuptools documentation 自行完成此操作。 ,或使用
Paster templates 创建包骨架.要使用 Paster 模板,请安装
PasteScript
进入你的虚拟环境:
pip install PasteScript
mkdir src
cd src/
paster create -t basic_package foobar
foobar
的包(或更准确地说,是一个 setuptools 发行版)。 .这是那个名字
easy_install
来安装您的软件包或 pip install foobar
setup.py
中其他软件包将使用的名称取决于您的软件包__init__.py
的目录)。这不是必需的,顶级 Python 包的名称可以是任何有效的包名称,但这是一个常见约定将其命名为与发行版相同的名称。这就是为什么将两者分开很重要但并不总是容易的原因。因为顶级 python 包名称是什么
import foobar
导入您的包或 from foobar import baz
cd foobar/foobar/
vim models.py
models.py
class Page(object):
"""A dumb object wrapping a webpage.
"""
def __init__(self, content, url):
self.content = content
self.original_url = url
def __repr__(self):
return "<Page retrieved from '%s' (%s bytes)>" % (self.original_url, len(self.content))
client.py
在使用
models.py
的同一目录中:
client.py
import requests
from foobar.models import Page
url = 'http://www.stackoverflow.com'
response = requests.get(url)
page = Page(response.content, url)
print page
requests
的依赖模块在
setup.py
:
install_requires=[
# -*- Extra requirements: -*-
'setuptools',
'requests',
],
src/foobar/
是您现在要置于版本控制之下的目录:
cd src/foobar/
git init
vim .gitignore
.gitignore
*.egg-info
*.py[co]
git add .
git commit -m 'Create initial package structure.
python setup.py develop
requests
依赖和你的包作为开发蛋。所以它链接到你的 virtualenv 的站点包,但仍然存在于
src/foobar
您可以在其中进行更改并使它们立即在 virtualenv 中处于事件状态,而无需重新安装您的软件包。
from foobar.models import Page
或类似的,声明该对象所在的完全限定名称。这使您的源代码更具可读性和可发现性,对于您自己和其他阅读您代码的人来说。
python client.py
来运行您的代码从激活的 virtualenv 中的任何位置。
python src/foobar/foobar/client.py
工作正常,您的软件包已正确安装,您的工作目录不再重要。
bin/something
您可以从 shell 运行的 virtualenv 中的脚本。
setup.py
entry_points='''
# -*- Entry points: -*-
[console_scripts]
run-fooobar = foobar.main:run_foobar
''',
client.py
def run_client():
# ...
main.py
from foobar.client import run_client
def run_foobar():
run_client()
python setup.py develop
bin/run-foo
.
/usr/local/bin/run-foo
或类似的地方,它将自动位于
$PATH
.
zest.releaser
关于python模块导入 - 相对路径问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27406957/
BufferedImage image = ImageIO.read(SpriteSheet.class.getResource(path)); BufferedImage image = Image
希望有人能够帮助我解决将我的 React 应用程序推送到 Heroku 时遇到的问题。 heroku 日志反复显示以下错误。 at=error code=H10 desc="App crashed"
我是 Kotlin 的新手,我正在经历这样的例子。 . . package com.example.lambda1 import spark.Spark.get fun main(args: Arra
如果您已经安装了 32 位 JDK,请在中定义一个 JAVA_HOME 变量 Computer>System Properties>System Setting>Enviorment VAriable
我正在开发一个独立于平台的应用程序。我收到一个文件 URL*。在 Windows 上,这些是: file:///Z:/folder%20to%20file/file.txt file://host/f
我在 OSX、Objective-C 上。 我有一个像 这样的路径/NSURL /Users/xxx/Desktop/image2.png 但我将它传递给第三方应用程序,该应用程序会像 excpect
我已经安装了 Android studio 和插件的 DART,FLUTTER 来启动 flutter,但是因为我在创建我的第一个 flutter 项目时无法提供 sdk 路径。 最佳答案 我试图找出
127.0.0.1:8000/api/仅包含来自第二个应用程序的 url,但我将两个 url 模块链接到相同的模式。甚至有可能做到这一点吗? 第一个应用程序: from django.urls imp
对于大量图像(大约 1k,加上相同数量的拇指,在大约 500 个文件夹中),我们要求网站上使用的所有图像 URI 都必须具有 SEO 优化路径。它们已经准备好并提供完整的路径结构(每个文件夹包含一个具
为什么 f 不是一个文件?什么可能导致这种情况? String currentPhotoPath = "file:/storage/sdcard0/Pictures/someFileName.
Gradle 中的项目名称或路径中允许使用哪些字符? 它是否与特定操作系统的目录名称中允许的字符相同(例如: http://en.wikipedia.org/wiki/Filename#Reserve
我有一个包含文件夹路径的表格。我需要找到层次结构中这些文件夹之间的所有“差距”。我的意思是,如果表格包含这 3 个文件夹: 'A' 'A\B\C' 'A\B\C\D\E\F\G' 我需要在层次结构中找
我在 Linux 服务器上的/home/subversion 中安装了 svn - 那里有一个 ROOT 文件夹,其中包含 db 和 conf 等文件夹。没有映射到项目名称的文件夹,请有人告诉我如何列
对于我的图像位置:/src/assets/bitmap/sample.jpg 给出了关键配置: context: resolve('src') output: { path: resolve('b
我需要创建带有圆角的 SVG 路径,以将它们导出到 DXF 进行切割。我的问题是角应该是圆弧,而不是贝塞尔曲线。 使用 arc 命令相对容易处理直角,因为半径也是从拐角到圆弧起点的距离。对于其他角度,
大家好,我正在玩 Airflow,我正在阅读这篇很有帮助的 tutorial .我正在寻求帮助以更好地了解 Admin->Connection 如何在 Conn Type: File (path) 方
我的目标是定义R将用于安装和搜索库的单个路径。我read可以通过更改Rprofile.site安装路径中的R文件来完成。我在那里尝试了两个命令: .libPaths("D:/RLibrary") .L
我有一个问题:当我在一个页面中时,我想返回到上一页。我使用 $routeProvider。如何读取之前的 url? 我尝试在我的 Controller 中使用此代码但不起作用... angular.m
我正在尝试将一个文件从我的主干合并到一个分支(wc),并且对于看起来位于当前合并操作中不涉及的分支上的路径出现奇怪的未找到路径错误。 例如,在我们的 svn 项目中,我们有: 分行 分支 0 分支 1
我有一个树数据序列化如下: 关系:P到C是“一对多”,C到P是“一对一”。所以列 P 可能有重复的值,但列 C 有唯一的值。 P, C 1, 2 1, 3 3, 4 2, 5 4, 6 # in da
我是一名优秀的程序员,十分优秀!