- 以下代码相当于一个模板,只用更改name字段出,改为对应的需要安装的模块名称就可以,比如这里是:scrapy_plus
- 将setup.py文件放到scrapy_plus的同级目录下
from os.path import dirname, join
# from pip.req import parse_requirements
from setuptools import (
find_packages,
setup,
)
def parse_requirements(filename):
""" load requirements from a pip requirements file """
# []是列表 ()是一个可迭代对象
lineiter = (line.strip() for line in open(filename))
# 返回去除空行和包含# 以外的所有内容
return [line for line in lineiter if line and not line.startswith("#")]
with open(join(dirname(__file__), './VERSION.txt'), 'rb') as f:
version = f.read().decode('ascii').strip()
setup(
name='scrapy-plus', # 模块名称
# 版本号
version=version,
# 描述
description='A mini spider framework, like Scrapy', # 描述
# 需要打包的package,使用find_packages 来动态获取package,exclude参数的存在,使打包的时候,排除掉这些文件
packages=find_packages(exclude=[]),
# 作者
author='it',
# 作者邮箱
author_email='your@email.com',
# 通信方式apache [该协议的意思是可以引用,但是必须标注原作者才可以]
license='Apache License v2',
# # 任何包文件都加進去,可以处理多层package目录结构
package_data={'': ['*.*']},
# 所要访问的链接
url='#',
install_requires=parse_requirements("requirements.txt"), # 所需的运行环境
# 加密压缩
zip_safe=False,
# 适配的环境
classifiers=[
'Programming Language :: Python',
'Operating System :: Microsoft :: Windows',
'Operating System :: Unix',
'Programming Language :: Python :: 2.7',
'Programming Language :: Python :: 3.4',
'Programming Language :: Python :: 3.5',
'Programming Language :: Python :: 3.6',
],
)
注意: 上面代码中可能会报错需要额外安装packaging模块,更新setuptools
pip install packaging
pip install --upgrade setuptools
pip.req可能不存在,对应的可以:
def parse_requirements(filename):
""" load requirements from a pip requirements file """
lineiter = (line.strip() for line in open(filename))
return [line for line in lineiter if line and not line.startswith("#")]