- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我使用How to show data labels when you mouse over data上的示例制作图像,当您将鼠标悬停在各个点上时会在其中显示数据。这确实很好,但是有某种保存方法,可以将图像发送给其他人吗?我不确定哪种格式支持“工具提示”,但是pdf和svg都支持,也许还有其他方法?
如果我需要打包可执行文件,在Linux中最简单的方法是什么?
最佳答案
正如您所建议的那样,也许有一些方法可以使svg和一些javascript或pdf工具提示起作用(直到您提到它们,我才知道pdf工具提示!)。
顺便说一句,我应该花点时间提及 mpld3
,它使用d3
将matplotlib图形重新创建为javascript可视化。它确实允许非常共享的交互式图形,并提供了一些制作交互式工具提示的示例。
但是,我不确定如何使matplotlib的svg文件具有一般性的交互性,并且您提到您不希望使用javascript路线,因此,我将指导您构建“独立”可执行文件(或者,更确切地说, ,一个包含可执行文件和相关库的目录)。
使用cx_freeze
和matplotlib
构建“独立”可执行文件
至少在打包可执行文件方面,我建议cx_freeze
。还有很多其他选项(例如pyinstaller
,py2exe
,py2app
等),但是其中大多数都是特定于平台的,对于我的口味来说有点“神奇”。 cx_freeze
需要更多的知识才能使用,但是它相当可靠,并且一旦您知道需要包括什么内容就不会太难使用。
首先,可以在这里找到我要向您介绍的完整示例:https://gist.github.com/joferkington/9214844它使用示例脚本和作为先前问题的一部分提供的数据。
关键是要构建一个setup.py
文件,该文件正确引用1)matplotlib的数据文件和2)您需要在代码中包含的所有数据才能使其正确运行。
之后,它就像python setup.py build_exe
和tar创建的要发送给其他人的构建目录一样简单。 (您可能想做一些更奇特的事情。可以使包含脚本数据,库和可执行文件的shell脚本成为可能,但在此我将跳过该部分。)
制作setup.py
文件
在setup.py
上。假设您有一个简单的名为plot.py
的脚本,其中包含一些基本的绘图代码,以及一个名为data.csv
的文件,其中包含要通过matplotlib
进行绘制的数据,等等。setup.py
的cx_freeze
文件看起来像这样:我假设您使用的是Matplotlib的Tk后端。如果您不使用,则情况会略有不同。)
import cx_Freeze
import sys
import matplotlib
base = None
if sys.platform == "win32":
base = "Win32GUI"
executables = [
cx_Freeze.Executable("plot.py", base = base),
]
build_exe_options = {"includes":["matplotlib.backends.backend_tkagg"],
"include_files":[(matplotlib.get_data_path(), "mpl-data"),
('data.csv', 'data.csv')],
"excludes":[],
}
cx_Freeze.setup(
name = "script",
options = {"build_exe": build_exe_options},
version = "0.0",
description = "A basic example",
executables = executables)
x_Freeze.Executable("plot.py", base = base)
)"includes"
中的build_exe_options
部分。 cx_freeze
将尝试自动猜测它需要包含哪些模块,但是在某些情况下,无法检测到它需要的所有内容。本部分允许您指定要显式包括的其他模块。通常不会正确自动检测到matplotlib后端,因此您需要明确包含正在使用的任何后端。 "include_files"
中的build_exe_options
部分。这表示需要包含的任何其他数据文件。 Matplotlib有一些数据文件(图标等),这些文件需要与代码和库一起提供,以使事情正常运行。 (matplotlib.get_data_path(), "mpl-data")
行获取这些文件,并将它们放在构建目录内的一个名为“mpl-data”的文件夹中。同样,('data.csv', 'data.csv')
行获取您的“data.csv”文件,并将其以相同的名称保存在构建目录中。 "excludes"
选项。这完全是可选的,但是
cx_freeze
通常将包含许多实际上不需要脚本运行的库。如果您希望缩小要分发的文件的大小,则可能需要列出要排除在此处的特定python模块。 (例如
"excludes":['PyQt4', 'scipy']
)
$ ls
data.csv plot.py setup.py
data.csv
具有我们的数据,
plot.py
是绘制数据的脚本,
setup.py
如上所述。
python setup.py build_exe
setup.py
文件出问题的有用信息。)
build
的新目录。
$ ls
build data.csv plot.py setup.py
build
将包含一个名称类似于以下内容的目录:
$ ls build
exe.linux-x86_64-2.7
exe.whatever
目录包含您需要分发给人们以使事情正常运行的库,数据和可执行文件。
cd
记录到目录中!!稍后对此进行更多说明。):
$ cd build/exe.linux-x86_64-2.7
$ ./plot
plot.py
,则可执行文件将不会称为
plot
,但您会明白的。)
exe.whatever
告诉人们运行它。
cd name_of_dir; ./plot
明确地插入目录。这纯粹是由于
cd
在当前目录中查找名为
plot.py
的文件这一事实的结果。
data.csv
中有一行可以做到:
df = pd.read_csv('data.csv', ...)
plot.py
足够聪明,可以包含
setup.py
,但是读取它的代码希望它位于当前目录中。
data.csv
放入目录中(实际上,提供一个简短的脚本,将cd
放入其中,运行该程序,然后将cd
退回)。如果您不想打扰第二个选项,则此方法非常有用。 cd
)。
plot.py
的路径来确定相对于脚本本身的位置。但是,对于
__file__
,将不会定义
cx_freeze
,而所需的路径将改为
__file__
。因此,您通常会执行以下操作:(来自cx_freeze常见问题解答:
http://cx-freeze.readthedocs.org/en/latest/faq.html#data-files)
def find_data_file(filename):
if getattr(sys, 'frozen', False):
# The application is frozen
datadir = os.path.dirname(sys.executable)
else:
# The application is not frozen
# Change this bit to match where you store your data files:
datadir = os.path.dirname(__file__)
return os.path.join(datadir, filename)
pd.read_csv('data.csv', ...)
pd.read_csv(find_data_file('data.csv'), ...)
sys.executable
文件中完成。作为练习,我将其留给读者。)
plot.py
。
/path/to/where/the/directory/gets/copied/plot
,您将交付一个充满了库和一个可执行文件的文件夹。
cx_freeze
即可。您可能希望将文件夹从
where/they/extracted/it/name_of_the_execuctable
重命名为
exe.linux-x86_64-2.7
之类,并包含一个名为
my_package
或其他名称的shell脚本,但这取决于您。
run_this
文件。桌面文件必须具有绝对路径,因此在这种情况下,您需要做更多的事情。通常,您会编写某种安装程序脚本,该脚本会修改
.desktop
以指向程序安装位置的绝对路径。
关于python - 与他人共享mpldatacursor的图像,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/22021297/
我正在处理一组标记为 160 个组的 173k 点。我想通过合并最接近的(到 9 或 10 个组)来减少组/集群的数量。我搜索过 sklearn 或类似的库,但没有成功。 我猜它只是通过 knn 聚类
我有一个扁平数字列表,这些数字逻辑上以 3 为一组,其中每个三元组是 (number, __ignored, flag[0 or 1]),例如: [7,56,1, 8,0,0, 2,0,0, 6,1,
我正在使用 pipenv 来管理我的包。我想编写一个 python 脚本来调用另一个使用不同虚拟环境(VE)的 python 脚本。 如何运行使用 VE1 的 python 脚本 1 并调用另一个 p
假设我有一个文件 script.py 位于 path = "foo/bar/script.py"。我正在寻找一种在 Python 中通过函数 execute_script() 从我的主要 Python
这听起来像是谜语或笑话,但实际上我还没有找到这个问题的答案。 问题到底是什么? 我想运行 2 个脚本。在第一个脚本中,我调用另一个脚本,但我希望它们继续并行,而不是在两个单独的线程中。主要是我不希望第
我有一个带有 python 2.5.5 的软件。我想发送一个命令,该命令将在 python 2.7.5 中启动一个脚本,然后继续执行该脚本。 我试过用 #!python2.7.5 和http://re
我在 python 命令行(使用 python 2.7)中,并尝试运行 Python 脚本。我的操作系统是 Windows 7。我已将我的目录设置为包含我所有脚本的文件夹,使用: os.chdir("
剧透:部分解决(见最后)。 以下是使用 Python 嵌入的代码示例: #include int main(int argc, char** argv) { Py_SetPythonHome
假设我有以下列表,对应于及时的股票价格: prices = [1, 3, 7, 10, 9, 8, 5, 3, 6, 8, 12, 9, 6, 10, 13, 8, 4, 11] 我想确定以下总体上最
所以我试图在选择某个单选按钮时更改此框架的背景。 我的框架位于一个类中,并且单选按钮的功能位于该类之外。 (这样我就可以在所有其他框架上调用它们。) 问题是每当我选择单选按钮时都会出现以下错误: co
我正在尝试将字符串与 python 中的正则表达式进行比较,如下所示, #!/usr/bin/env python3 import re str1 = "Expecting property name
考虑以下原型(prototype) Boost.Python 模块,该模块从单独的 C++ 头文件中引入类“D”。 /* file: a/b.cpp */ BOOST_PYTHON_MODULE(c)
如何编写一个程序来“识别函数调用的行号?” python 检查模块提供了定位行号的选项,但是, def di(): return inspect.currentframe().f_back.f_l
我已经使用 macports 安装了 Python 2.7,并且由于我的 $PATH 变量,这就是我输入 $ python 时得到的变量。然而,virtualenv 默认使用 Python 2.6,除
我只想问如何加快 python 上的 re.search 速度。 我有一个很长的字符串行,长度为 176861(即带有一些符号的字母数字字符),我使用此函数测试了该行以进行研究: def getExe
list1= [u'%app%%General%%Council%', u'%people%', u'%people%%Regional%%Council%%Mandate%', u'%ppp%%Ge
这个问题在这里已经有了答案: Is it Pythonic to use list comprehensions for just side effects? (7 个答案) 关闭 4 个月前。 告
我想用 Python 将两个列表组合成一个列表,方法如下: a = [1,1,1,2,2,2,3,3,3,3] b= ["Sun", "is", "bright", "June","and" ,"Ju
我正在运行带有最新 Boost 发行版 (1.55.0) 的 Mac OS X 10.8.4 (Darwin 12.4.0)。我正在按照说明 here构建包含在我的发行版中的教程 Boost-Pyth
学习 Python,我正在尝试制作一个没有任何第 3 方库的网络抓取工具,这样过程对我来说并没有简化,而且我知道我在做什么。我浏览了一些在线资源,但所有这些都让我对某些事情感到困惑。 html 看起来
我是一名优秀的程序员,十分优秀!