当前位置: 首页 > news >正文

python自己造轮子使用

项目结构

首先,需要按照下列格式组织你的 package

project                                    (项目名称,随意,与package无关)|----package                           (这个才是包名)|----__init__.py                   (__init__包内每个文件夹下都要有)|----code.py                       (具体的代码)|----other                             (package外可以放一些doc, img之类的,不会被封装到package中)|----__init__.py                       (空着即可)|----setup.py                          (构建脚本)

init.py 如何写?
对于包内的 init.py文件的写法,以下面的包内文件结构为例

|----rofunc                                 (包名)|----devices                            (一级文件夹)|----xsens                          (二级文件夹)|----record.py                  (包含record函数)|----process.py                 (包含data_clean函数)|----__init__.py                (三级__init__)|----optitrack|----record.py|----process.py|----__init__.py|----...|----__init__.py                    (二级__init__)|----lfd|----...                    |----__init__.py                        (一级__init__)

那么如果想要实现以下索引,该怎么写这几层的__init__.py呢?

import rofunc as rf
rf.xsens.data_clean(...)

1.需要在一级__init__.py中

from __future__ import absolute_importfrom .devices import xsens, optitrack, ...
  1. 二级__init__.py空着
  2. 三级__init__.py
from __future__ import absolute_importfrom .record import *
from .process import *

具体在你的包中该如何组织多层__init__.py,实际上要看你对于功能调用格式的设计了。

setup.py 如何写?

# -*- coding:utf-8 -*-
from distutils.core import setup
from setuptools import find_packagessetup(name='declare',version='0.1',packages=find_packages(where='src\\'),  # 查找包的路径package_dir={'': 'src'},  # 包的root路径映射到的实际路径include_package_data=False,package_data={'data': []},description='A python lib for xxxxx',long_description='',author='python developer',author_email='xxxxxxx@qq.com',url='http://www.xxxxx.com/',  # homepagelicense='MIT',install_requires=['requests', 'selenium', 'baidu-aip', 'pillow', 'pywin32'],)
# name : 打包后包的文件名
# version : 版本号
# author : 作者
# author_email : 作者的邮箱
# py_modules : 要打包的.py文件
# packages: 打包的python文件夹
# include_package_data : 项目里会有一些非py文件,比如html和js等,这时候就要靠include_package_data 和 package_data 来指定了。package_data:一般写成{‘your_package_name’: [“files”]}, include_package_data还没完,还需要修改MANIFEST.in文件.MANIFEST.in文件的语法为: include xxx/xxx/xxx/.ini/(所有以.ini结尾的文件,也可以直接指定文件名)
# license : 支持的开源协议
# description : 对项目简短的一个形容
# ext_modules : 是一个包含Extension实例的列表,Extension的定义也有一些参数。
# ext_package : 定义extension的相对路径
# requires : 定义依赖哪些模块
# provides : 定义可以为哪些模块提供依赖
# data_files :指定其他的一些文件(如配置文件),规定了哪些文件被安装到哪些目录中。如果目录名是相对路径,则是相对于sys.prefix或sys.exec_prefix的路径。如果没有提供模板,会被添加到MANIFEST文件中。

实例

from setuptools import setup, find_packagessetup(name="rofunc",version="0.0.0.9",description='The Full Process Python Package for Robot Learning from Demonstration',author="Junjia Liu",author_email="jjliu@mae.cuhk.edu.hk",url='https://github.com/Skylark0924/Rofunc',packages=find_packages(),install_requires=['matplotlib', 'pandas', 'tqdm', 'pillow', 'pytransform3d', 'tensorflow', 'numpy==1.21.6','nestle','pbdlib @ https://github.com/Skylark0924/Rofunc/releases/download/v0.0.0.7.1/pbdlib-0.1-py3-none-any.whl'],python_requires=">=3.6,<3.11",keywords=['robotics', 'learning from demonstration'],license='MIT',classifiers=["Programming Language :: Python :: 3","License :: OSI Approved :: MIT License","Operating System :: OS Independent",],
)

这里重点介绍一下 install_requires 的一些冷知识:如果依赖的包没有发布在PYPI,又不想/不能封在自己的包内,那么可以参照我对于 Sylvain Calinon 老师的pbdlib包的处理方法。

pbdlib包是一个托管在 Gitlab 上的示教/模仿学习python库,原地址为 https://gitlab.idiap.ch/rli/pbdlib-python 。可以发现,这个库里是有setup.py的,但是只被用来做 git clone 之后的本地安装。我的解决方案是:

本地打包(参照下一节的内容):git clone …
python setup.py bdist_wheel sdist
你会发现,主目录下会生成build和dist两个文件夹,dist下可以找被我们称作“轮子”的,对该库封装的压缩包pbdlib-0.1-py3-none-any.whl
将其作为Release文件,上传到github的某个版本的Release中(当然,你自己有个人网站也是可以的,能够完整下载就行)
在install_requires中,以包名+url的形式加入依赖’pbdlib @ https://github.com/Skylark0924/Rofunc/releases/download/v0.0.0.7.1/pbdlib-0.1-py3-none-any.whl’
即可实现用户只需pip install rofunc,自动安装pbdlib依赖库。
很遗憾的是,尽管这样的写法允许我们在本地安装的时候直接安装这些未上传到PYPI的依赖,但是由于规则限制,拥有这种直接链接的package无法被推送到pypi。会收到如下报错:

HTTPError: 400 Client Error: '[your requirements]' is an invalid value for Version. Error: Can't use PEP 440 local versions. See https://packaging.python.org/specifications/core-metadata for url: https://test.pypi.org/legacy/:

详情请参见 issue 430,以及这个链接。
·https://link.zhihu.com/?target=https%3A//github.com/pypa/twine/issues/430
·https://link.zhihu.com/?target=https%3A//resultfor.dev/670121-how-can-i-use-git-repos-as-dependencies-for-my-pypi-package

包内数据
Setuptools有关于这部分的教程,但是你会发现需要指定文件类型,而且每个文件夹下都要有一个__init__.py。这么麻烦的方式肯定不适合把整个文件夹的数据打包起来。于是,我就发现可以通过在project目录下再写一个 MANIFEST.in文件来实现。通过直接指定想要添加的数据路径就ok了recursive-include rofunc/data/ *
recursive-include rofunc/simulator/assets/ *
此外,还需要在setup.py文件中加一行来指向MANIFEST.in文件include_package_data=True

Python setup.py和MANIFEST.in文件
https://link.zhihu.com/?target=https%3A//blog.csdn.net/fragmentalice/article/details/44833013

The MANIFEST.in template
https://link.zhihu.com/?target=https%3A//docs.python.org/2/distutils/sourcedist.html%23the-manifest-in-template

打包、安装与推送

打包
python setup.py bdist_wheel            # 打包为whl文件
python setup.py sdist                  # 打包为tar.gz文件python setup.py bdist_wheel sdist      # 也可以一起写,省事

或者直接

python -m build

本地安装


执行完之后会在当前目录生成 dist 文件夹,文件夹内部是编译好的 python 包,whl 后缀结尾cd dist
执行安装命令pip install rofunc-0.0.0.9-py3-none-any.whl
卸载pip uninstall rofunc

相关文章:

python自己造轮子使用

项目结构 首先&#xff0c;需要按照下列格式组织你的 package project &#xff08;项目名称&#xff0c;随意&#xff0c;与package无关&#xff09;|----package &#xff08;这个才是包名&#xff09;|----…...

Elastic stack8.10.4搭建、启用安全认证,启用https,TLS,SSL 安全配置详解

ELK大家应该很了解了&#xff0c;废话不多说开始部署 kafka在其中作为消息队列解耦和让logstash高可用 kafka和zk 的安装可以参考这篇文章 深入理解Kafka3.6.0的核心概念&#xff0c;搭建与使用-CSDN博客 第一步、官网下载安装包 需要 elasticsearch-8.10.4 logstash-8.…...

解决npm报错Error: error:0308010C:digital envelope routines::unsupported

解决npm报错Error: error:0308010C:digital envelope routines::unsupported。 解决办法&#xff1b;终端执行以下命令&#xff08;windows&#xff09;&#xff1a; set NODE_OPTIONS--openssl-legacy-provider然后再执行 npm命令成功&#xff1a;...

高防IP是什么?有什么优势?

一.高防IP的概念 高防IP是指高防机房所提供的IP段&#xff0c;一种付费增值服务&#xff0c;主要是针对网络中的DDoS攻击进行保护。用户可以通过配置高防IP&#xff0c;把域名解析到高防IP上&#xff0c;引流攻击流量&#xff0c;确保源站的稳定可靠。 二.高防IP的原理 高防I…...

php费尔康框架phalcon(费尔康)框架学习笔记

phalcon(费尔康)框架学习笔记 以实例程序invo为例(invo程序放在网站根目录下的invo文件夹里&#xff0c;推荐php版本>5.4) 环境不支持伪静态网址时的配置 第一步&#xff1a; 在app\config\config.ini文件中的[application]节点内修改baseUri参数值为/invo/index.php/或…...

StartUML的基本使用

文章目录 简介和安装创建包创建类视图时序图 简介和安装 最近在学习一个项目的时候用到了StartUML来构造项目的类图和时序图 虽然vs2019有类视图&#xff0c;但是也不是很清晰&#xff0c;并没有生成uml图&#xff0c;但是宇宙最智能的IDE IDEA有生成uml图的功能 下面就简单介…...

飞天使-django概念之urls

urls 容易搞混的概念&#xff0c;域名&#xff0c;主机名&#xff0c;路由 网站模块多主机应用 不同模块解析不同的服务器ip地址 网页模块多路径应用 urlpatterns [ path(‘admin/’, admin.site.urls), path(‘’, app01views.index), path(‘movie/’, app01views.movi…...

MongoDB分片集群搭建

----前言 mongodb分片 一般用得比较少&#xff0c;需要较多的服务器&#xff0c;还有三种的角色 一般把mongodb的副本集应用得好就足够用了&#xff0c;可搭建多套mongodb复本集 mongodb分片技术 mongodb副本集可以解决数据备份、读性能的问题&#xff0c;但由于mongodb副本集是…...

modbus报文

MODBUS规约报文解析-CSDN博客...

flutter报错: library “libflutter.so“ not found

修改android/app/build.gradle defaultConfig { // TODO: Specify your own unique Application ID (https://developer.android.com/studio/build/application-id.html). applicationId "cn.rentsoft.flutter.openim.consumer" // You can update the …...

MR混合现实情景实训教学系统模拟历史情景

二、应用场景 1. 古代战争场景&#xff1a;通过MR混合现实情景实训教学系统&#xff0c;学生可以亲身体验古代战争的场景&#xff0c;如战场布置、战术运用等。这不仅有助于学生更好地理解古代战争的特点&#xff0c;还能够培养他们的团队协作和战略思维能力。 2. 历史文化古…...

计算机视觉的应用16-基于pytorch框架搭建的注意力机制,在汽车品牌与型号分类识别的应用

大家好&#xff0c;我是微学AI&#xff0c;今天给大家介绍一下计算机视觉的应用16-基于pytorch框架搭建的注意力机制&#xff0c;在汽车品牌与型号分类识别的应用&#xff0c;该项目主要引导大家使用pytorch深度学习框架&#xff0c;并熟悉注意力机制模型的搭建&#xff0c;这个…...

Flutter 实现 Android CollapsingToolbarLayout折叠布局效果

Flutter 是通过Tabbar TabbarView 来实现 类似Android Viewpager 页面切换的效果的。我个人觉得Flutter 的tab 切换实现过程要比Android的实现过程要简单容易不是一星半点&#xff0c;哈哈哈哈 &#xff0c;因为她所用到的widget 都是google 官方封装好的&#xff0c;用起来代…...

数据库管理-第116期 Oracle Exadata 06-ESS-下(202301114)

数据库管理-第116期 Oracle Exadata 06-ESS-下&#xff08;202301114&#xff09; 距离上一次正儿八经的技术分享又过了整整一周了&#xff0c;距离上一期Exadata专题文章也过了11天了&#xff0c;今天一鼓作气把ESS写完&#xff0c;毕竟明天又要飞北京了。 1 Smart Scan 其…...

阿里云C++二面面经

1.智能指针 1、shared_ptr 原理:shared_ptr是基于引用计数的智能指针,用于管理动态分配的对象。无论 std::shared_ptr 存储在堆区还是栈区,它所指向的内存块始终存储在堆区。这是因为 std::shared_ptr 是用于管理动态分配的内存的智能指针,它需要存储在堆区,以便进行引用…...

Ubuntu 20.04编译Chrome浏览器

本文记录chrome浏览器编译过程&#xff0c;帮助大家避坑qaq 官网文档&#xff1a;https://chromium.googlesource.com/chromium/src//main/docs/linux/build_instructions.md 一.系统要求 一台64位的英特尔机器&#xff0c;至少需要8GB的RAM。强烈推荐超过16GB。至少需要100…...

大文件分片上传、断点续传、秒传

小文件上传 后端&#xff1a;SpringBootJDK17 前端&#xff1a;JavaScriptsparkmd5.min.js 一、依赖 <parent><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-parent</artifactId><version>3.1.2</ve…...

DAY53 1143.最长公共子序列 + 1035.不相交的线 + 53. 最大子序和

1143.最长公共子序列 题目要求&#xff1a;给定两个字符串 text1 和 text2&#xff0c;返回这两个字符串的最长公共子序列的长度。 一个字符串的 子序列 是指这样一个新的字符串&#xff1a;它是由原字符串在不改变字符的相对顺序的情况下删除某些字符&#xff08;也可以不删…...

短剧App开发:个性化的内容推荐

随着移动互联网的普及和用户需求的多样化&#xff0c;短剧App作为一种新兴的内容消费模式&#xff0c;受到了越来越多用户的青睐。在短剧App开发中&#xff0c;个性化的内容推荐是一个重要的功能&#xff0c;它能够根据用户的兴趣偏好和行为数据&#xff0c;为他们提供更精准、…...

互斥量保护资源

一、概念 在多数情况下&#xff0c;互斥型信号量和二值型信号量非常相似&#xff0c;但是从功能上二值型信号量用于同步&#xff0c; 而互斥型信号量用于资源保护。 互斥型信号量和二值型信号量还有一个最大的区别&#xff0c;互斥型信号量可以有效解决优先级反转现 象。 …...

机器人双目视觉定位系统设计与开发

机器人双目视觉定位系统设计与开发 摘要 双目视觉定位技术是机器人感知环境、实现自主导航和精准操作的核心技术之一。本系统基于双目立体视觉原理,利用Matlab平台完成了从相机标定、图像采集、立体匹配到三维坐标解算的完整流程。系统采用张正友标定法获取相机内外参数,通…...

收藏备用!AI大模型自学路线(小白/程序员专属),从入门到实战少走90%弯路

当下AI大模型已成技术领域的核心热点&#xff0c;无论是零基础小白&#xff0c;还是想转型进阶的程序员&#xff0c;都纷纷投身其中。但自学过程中&#xff0c;多数人都会陷入“找不到方向、学了不会用、越学越迷茫”的困境。今天就为大家整理一份系统、可落地、无冗余的AI大模…...

日结零工市场的权益保障困境与系统性治理路径

一、现象审视&#xff1a;弱势单元的权益真空日结零工作为弹性用工体系中最灵活、最底层的用工形态&#xff0c;其劳动者长期处于权益保障的真空地带。本文基于对B市线上日结零工市场的田野研究发现&#xff0c;日结零工劳动者面临三重结构性弱势&#xff1a;第一&#xff0c;法…...

基于Matlab的路面裂缝检测识别系统:实现精准路面“体检”

基于Matlab的路面裂缝检测识别系统设计&#xff0c;载入待识别图片&#xff0c;对目标图像进行直方图均衡化、中值滤波去噪、对比度增强、二值化处理、二值化滤波、裂缝识别、裂缝判断、裂分拼接、裂缝投影及标记等一系列操作&#xff0c;完成路面识别的准确识别 程序已调通&am…...

Agentic SOC:AI原生时代,安全运营的终极范式革命

2026年RSAC全球网络安全大会上&#xff0c;一个现象级的行业转折正在发生&#xff1a;全场超过90%的主流安全厂商将核心展位与重磅发布聚焦于Agentic SOC&#xff0c;全球500强企业中超过62%已启动相关试点&#xff0c;21%完成了核心生产环境的规模化落地。与之形成强烈对比的是…...

Facebook Instant Game变现全攻略:如何通过广告和内购让你的HTML5游戏赚钱

Facebook Instant Game变现全攻略&#xff1a;如何通过广告和内购让你的HTML5游戏赚钱 在HTML5游戏开发领域&#xff0c;Facebook Instant Game已经成为不可忽视的平台。这个无需下载、即点即玩的游戏生态系统&#xff0c;为开发者提供了独特的变现机会。不同于传统应用商店30%…...

VisualCppRedist AIO:一个文件解决Windows运行库的十年难题

VisualCppRedist AIO&#xff1a;一个文件解决Windows运行库的十年难题 【免费下载链接】vcredist AIO Repack for latest Microsoft Visual C Redistributable Runtimes 项目地址: https://gitcode.com/gh_mirrors/vc/vcredist 你是否曾在打开心爱的游戏或专业软件时&a…...

如何用STM32CubeMX快速配置Simulink硬件在环项目?STM32G4xx实战演示

STM32CubeMX与Simulink硬件在环开发实战&#xff1a;从零构建电机控制验证平台 当工程师需要验证一个新型电机控制算法时&#xff0c;传统方式往往需要经历PCB设计、焊接调试、反复烧录的漫长周期。而现在&#xff0c;通过STM32CubeMX与Simulink的硬件在环&#xff08;HIL&…...

ChatGPT_JCM前端构建工具对比:Webpack、Vite与Rollup

ChatGPT_JCM前端构建工具对比&#xff1a;Webpack、Vite与Rollup 【免费下载链接】ChatGPT_JCM 项目地址: https://gitcode.com/gh_mirrors/ch/ChatGPT_JCM ChatGPT_JCM是一个基于AI技术的前端项目&#xff0c;在开发过程中选择合适的构建工具对于提升开发效率和优化项…...

UniApp项目实战:手把手教你用云函数搞定UniPush 2.0服务端消息推送

UniPush 2.0云函数实战&#xff1a;从零构建高可用消息推送系统 在移动应用生态中&#xff0c;消息推送是维系用户活跃度的关键触达手段。UniPush 2.0作为DCloud推出的新一代推送服务&#xff0c;通过云函数与厂商通道的深度整合&#xff0c;解决了传统推送方案中离线到达率低、…...