用Python和py2app写独立的Mac OS X 应用

文/lovexiaov(简书作者)
原文链接:http://www.jianshu.com/p/afb6b2b97ce9
著作权归作者所有,转载请联系作者获得授权,并标注“简书作者”。

前提

创建一个普通文件夹,并创建一个virtualenv环境:

# Create a custom directory
$ mkdir SandwichApp
$ cd SandwichApp

# Use virtualenv to create an isolated environment
$ virtualenv venv
$ . venv/bin/activate

现在,创建一个简单的Tkinter应用,并其命名为 Sandwich.py

import sys
if sys.version_info < (3, 0):
    # Python 2
    import Tkinter as tk
else:
    # Python 3
    import tkinter as tk
root = tk.Tk()
root.title("Sandwich")
tk.Button(root, text="Make me a Sandwich").pack()
tk.mainloop()
 

这个小应用是这个样子:

app_screen.png

安装 py2app

原版的 py2app 由于 ModuleGraph 更新了版本产生了一个 bug。我 fork 了该工程,解决了 bug,然后放到了 Github。使用 pip 安装 py2app:

$ pip install -U git+https://github.com/metachris/[email protected]master

创建 setup.py 文件

py2app 包含了 py2applet 工具, 此工具可以帮你创建 setup.py 文件:

$ py2applet --make-setup Sandwich.py
Wrote setup.py

setup.py 文件是对应用的基本定义:

from setuptools import setup

APP = [‘Sandwich.py‘]
DATA_FILES = []
OPTIONS = {‘argv_emulation‘: True}

setup(
    app=APP,
    data_files=DATA_FILES,
    options={‘py2app‘: OPTIONS},
    setup_requires=[‘py2app‘],
)
如果你的应用使用的其他文件,比如 JSON 文件,文本文件,图片等,你应该将他们包含在 DATA_FILES 中。 例如:
DATA_FILES = [‘testdata.json‘, ‘picture.png‘]

创建开发版和测试版的应用

py2app 基于在 setup.py 文件的定义创建独立应用。

为了方法测试和开发,py2app 提供了“别名模式”,该模式通过与开发文件象征性的链接构建应用。

$ python setup.py py2app -A

此命令创建了如下文件和文件夹:

.
├── build
│   └── bdist.macosx-10.10-x86_64
│       └── python2.7-standalone
│           └── app
│               ├── Frameworks
│               ├── collect
│               ├── lib-dynload
│               └── temp
├── Sandwich.py
├── dist
│   └── Sandwich.app
│       └── Contents
│           ├── Info.plist
│           ├── MacOS
│           │   ├── Sandwich
│           │   └── python -> /Users/chris/Projects/chris/python-gui/tkinter/env/bin/../bin/python
│           ├── PkgInfo
│           └── Resources
│               ├── __boot__.py
│               ├── __error__.sh
│               ├── lib
│               │   └── python2.7
│               │       ├── config -> /Users/chris/Projects/chris/python-gui/tkinter/env/bin/../lib/python2.7/config
│               │       └── site.pyc -> ../../site.pyc
│               ├── site.py
│               └── site.pyc
└── setup.py

这并不是一个独立的应用,并且通过别名模式构建的应用不适用于其他机器。

别名模式下构建的应用直接引用了源码文件,所以任何对 Sandwich.py 文件作的修改在应用下次启动时会立刻生效。

位于 dist/Sandwich.app 的开发应用可以和其他 .app 应用一样,在 Finder 中或通过 open 命令($ open dist/Sandwich.app)启动。你可以在终端执行如下命令启动你的应用:

$ ./dist/Sandwich.app/Contents/MacOS/Sandwich

构建发布版应用

当测试通过后,你可以通过调用 python setup.py py2app 来生成发布版。确保旧的 builddist 文件类都被删除了:

$ rm -rf build dist
$ python setup.py py2app

此命令会将你的应用打包为 dist/Sandwich.app。由于该应用是自包含的,在任意时刻,如果你修改了代码,数据文件,选项等,你都可以再次运行 py2app 命令重新构建。

原版的 py2app 有一个 bug,会出现 “AttributeError: ‘ModuleGraph‘ object has no attribute ‘scan_code‘” 或者 load_module。如果你遇到此错误,请参考 StackOverflow 或者使用我的 py2app fork

此时此刻,最简单的打包并发布应用的方法是在 Finder 中右击该应用选择“创建归档”。

添加一个图标:

OPTIONS 字典中添加 "iconfile": "youricon.icns" 即可:

from setuptools import setup

APP = [‘Sandwich.py‘]
DATA_FILES = []
OPTIONS = {
    ‘argv_emulation‘: True,
    ‘iconfile‘: ‘app.icns‘
}

setup(
    app=APP,
    data_files=DATA_FILES,
    options={‘py2app‘: OPTIONS},
    setup_requires=[‘py2app‘],
)

  

你可以在网上找到 icns 格式的图标(例如:IconFinder或者freepik)。

应用高级设置

你可以通过修改 Info.plist 来调用应用的信息各行为。最完整的对可用的键的引用是Apple‘s Runtime Configuratin Guidelines

下面是一个有更多修改的例子:

# -*- coding: utf-8 -*-
from setuptools import setup

APP = [‘Sandwich.py‘]
APP_NAME = "SuperSandwich"
DATA_FILES = []

OPTIONS = {
    ‘argv_emulation‘: True,
    ‘iconfile‘: ‘app.icns‘,
    ‘plist‘: {
        ‘CFBundleName‘: APP_NAME,
        ‘CFBundleDisplayName‘: APP_NAME,
        ‘CFBundleGetInfoString‘: "Making Sandwiches",
        ‘CFBundleIdentifier‘: "com.metachris.osx.sandwich",
        ‘CFBundleVersion‘: "0.1.0",
        ‘CFBundleShortVersionString‘: "0.1.0",
        ‘NSHumanReadableCopyright‘: u"Copyright © 2015, Chris Hager, All Rights Reserved"
    }
}

setup(
    name=APP_NAME,
    app=APP,
    data_files=DATA_FILES,
    options={‘py2app‘: OPTIONS},
    setup_requires=[‘py2app‘],
)

  

 

通过设置,应用会拥有下面的信息:

get_info.png

时间: 2024-08-07 15:54:21

用Python和py2app写独立的Mac OS X 应用的相关文章

利用Python进行windows系统键盘控制功能(Mac OS系统也可以)

系统环境: 1.安装了python 2.安装了pyautogui模块 windows系统:无需安装依赖模块,在cmd中直接输入pip install pyautogui即可完成安装 Mac OS系统:需要先安装pyobjc模块,最后安装pyautogui pip install pyobjc-core pip install pyobjc pip install pyautogui 验证是否安装成功 在cmd下输入python,之后输入import pyautogui,再输入pyautogui.

(转)Mac OS X写了个rm时将文件放入回收站的小工具

上次由于公司里机器要面临重装,开始仓皇地将Mac本里的文件scp到我的台式机上.忙乱之中本来要删除一个无用的文件夹的,结果用rm -rf的时候tab了一下,补全出来的文件都没看清就按下了回车,毫无疑问,文件删错了.由于rm命令是不走回收站的,连删前确认都不会有,所以就这么把一个有用的文件夹删掉了.幸亏后来发现我曾在台式机上备份过这个文件,否则美好的回忆就因为这个操作失误而丢失了. 为了防止此类事件的再度发生,我曾在Twitter上询问过别人关于实现rm时只把文件送到回收站而不删除的命令.有些人说

在MAC OS 下配置python + Flask ,并支持pyCharm编辑器

原创咯- flask是一个micro framework ,伸缩性很强.可以部署到openshift 的PAAS里.这个框架上手非常快.喜欢的可以试试. 若实在MAC里,python已经默认安装了.10.9的系统安装的是2.7.5的版本.所以我们这里就不详细介绍python的安装啦 1. 首先安装  vurtualenv 这是一个虚拟环境,virtualenv 允许多个版本的 Python 同时存在,对应不同的项目. 它实际上并没有安装独立的 Python 副本,但是它确实提供了一种巧妙的方式来

[Python Fabric] [SSH] Mac OS X 10.9 + Vagrant虚拟环境使用Python Fabric进行SSH远程登录的简单实验

1. ssh客户端生成key 1 $ ssh-keygen -t rsa -b 4096 2 Generating public/private rsa key pair. 3 Enter file in which to save the key (/Users/(username)/.ssh/id_rsa): vagrantid_rsa 4 Enter passphrase (empty for no passphrase): 5 Enter same passphrase again: 6

Python 环境搭建(Win 安装以及Mac OS 安装)

千里之行始于足下,今天我们先来学习 Python 环境搭建. 注意:本系列教程基于 Python 3.X Python 环境搭建 Win 安装 打开 Python 官网 https://www.python.org/downloads/选择最新版本下载,或者直接打开对应的版本python-374(https://www.python.org/downloads/release/python-374/). 打开页面会看到有一个列表,如下图: x86是32位,x86-64是64位. 可以通过下面3种

Python代写,Python作业代写,代写Python,代做Python(微信leechanx)

Python代写,Python作业代写,代写Python,代做Python(微信leechanx) Redis:Cannot assign requested address的解决办法 客户端频繁的连服务器,由于每次连接都在很短的时间内结束,导致很多的TIME_WAIT,以至于用光了可用的端口号,所以新的连接没办法绑定端口,即"Cannot assign requestedaddress".是客户端的问题不是服务器端的问题.通过netstat,的确看到很多TIME_WAIT状态的连接.

代写Python、代做Python、Python作业代写、Python代写(微信leechanx)

代写Python.代做Python.Python作业代写.Python代写(微信leechanx) i++ VS ++i性能区别 i++ 为 function () { tmp = i; i = tmp + 1; return tmp; } ++i 为 function () { i = i + 1; return i; }

Mac OS X 下安装python的MySQLdb模块

参考资料: mac os x下python安装MySQLdb模块   http://www.codeif.com/post/1073/ MAC OSX使用Python安装模块有关问题  http://www.myexception.cn/operating-system/1616547.html 在Mac OS X 中安装好了MySQL和Django,在Django中访问MySQL数据库时,提示“ImportError: No module named MySQLdb”,是由于没有安装Pytho

转-在Mac OS上搭建Python的开发环境

在Mac OS上搭建Python的开发环境 本文转载自:http://www.jb51.net/article/76931.htm 一. 安装python mac系统其实自带了一个python的执行执行环境,用来运行python还行,但是开发可能就不够了,因此我们需要重新安装python.这里有两种方案安装: 1.homebrew 1 brew install python 这个方案比较简单,如果出错的话可以给前面加sudo试试,这个安装的python可能不是最新版. 2.从官网下载安装大家可以