How to quickly package a new Python module
When you install an application, you are usually installing a software package that contains the application's executable code and important files such as documents, icons, etc. On Linux, software is generally packaged into formats such as RPM or DEB. Users can install it through commands such as dnf
or apt
, depending on the Linux distribution you are using. . However, new Python modules are released almost every day, so it's easy to come across a Python module that hasn't been packaged yet. This is the meaning of pyp2rpm
's existence.
Recently I was trying to install a module called python-concentration
, but the progress was not very smooth:
$ sudo dnf install python-concentration Updating Subscription Management repositories. Last metadata expiration check: 1:23:32 ago on Sat 11 Jun 2022 06:37:25. No match for argument: python-concentration Error: Unable to find a match: python-concentration
Although this is a package published on PyPi, It still cannot be packaged into an RPM package. The good news is that you can package it into an RPM package in a relatively simple process using pyp2rpm
.
First you need to set up two directories:
$ mkdir rpmbuild $ cd rpmbuild && mkdir SPECS
Install like this pyp2rpm
:
$ sudo dnf install pyp2rpm
1. Generate spec file
The basis of the RPM package is a spec file. This file contains all the information you need to create this package, such as required dependencies, application version numbers, installed files and other information. When pointing to a Python module, pyp2rpm
will build a spec file for it, which you can use to create RPM packages.
The following uses python-concentration
as an example to demonstrate how to build a spec file:
$ pyp2rpm concentration > ~/rpmbuild/SPECS/concentration.spec
The following is the file it generates:
# Created by pyp2rpm-3.3.8 %global pypi_name concentration %global pypi_version 1.1.5 Name: python-%{pypi_name} Version:%{pypi_version} Release:1%{?dist} Summary:Get work done when you need to, goof off when you don't License:None URL:None Source0:%{pypi_source} BuildArch:noarch BuildRequires:python3-devel BuildRequires:python3dist(setuptools) %description Concentration [ >= 2.6.1 with python3dist(hug) < 3~~) Requires: python3dist(setuptools) %description -n python3-%{pypi_name} Concentration [ is required Record the date.
%changelog * Sat Jun 11 2022 Tux- 1.1.5-1
Run rpmint
again:
$ rpmlint ~/rpmbuild/SPEC/concentration.spec 0 packages and 1 specfiles checked; 0 errors, 0 warnings.
Success!
3. Download the source code
You need to download the packaged code to further build the RPM package. A simple way is to parse your spec file to get the URL of the source code.
First, install spectool
through dnf
:
$ sudo dnf install spectool
Then download the source code through spectool
:
$ cd ~/rpmbuild $ spectool -g -R SPEC/concentration.spec Downloading: https://files.pythonhosted.org/...concentration-1.1.5.tar.gz 6.0 KiB / 6.0 KiB[=====================================] Downloaded: concentration-1.1.5.tar.gz
This creates a SOURCES
directory and puts the source code into it.
4. Build the source software package
Now that you have verified the spec file, you can build the source software package through rpmbuild
. If you haven't installed rpmbuild
, you can also install the rpm-build
package via dnf
(or from the terminal when using the rpmbuild
command prompts for installation).
Parameter -bs
represents the build source package. Adding this parameter will produce a src.rpm file, which is a generic package for rebuilding for a specific architecture:
$ rpmbuild -bs SPECS/concentration.spec Wrote: ~/rpmbuild/SRPMS/python-concentration-1.1.5-1.el9.src.rpm
Build an installable RPM file for your system:
$ rpmbuild –rebuild SRPMS/python-concentration-1.1.5-1.el9.src.rpm error: Failed build dependencies: python3-devel is needed by python-concentration-1.1.5-1.el9.noarch
It seems that this package needs to install the Python development library to continue building. Install them to continue building. This time, the build succeeds, and more output is rendered (I've abbreviated the output here for clarity):
$ sudo dnf install python3-devel -y $ rpmbuild –rebuild SRPMS/python-concentration-1.1.5-1.el9.src.rpm [...] Executing(--clean): /bin/sh -e /var/tmp/rpm-tmp.TYA7l2 + umask 022 + cd /home/bogus/rpmbuild/BUILD + rm -rf concentration-1.1.5 + RPM_EC=0 ++ jobs -p + exit 0
Your RPM package is now built in the RPMS
subroutine directory, use dnf
to install it as usual.
$ sudo dnf install RPMS/noarch/python3-concentration*rpm
Why not use PyPi?
Normally we do not need to package Python modules into RPM packages. Installing modules through PyPi is also acceptable, but PyPi will install additional package managers to check and update your modules. When you use dnf
to install an RPM package, you will be able to get the complete installation list when the installation is complete. With pyp2rpm
, this process is fast, easy, and automated.
The above is the detailed content of How to quickly package a new Python module. For more information, please follow other related articles on the PHP Chinese website!

Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

AI Hentai Generator
Generate AI Hentai for free.

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics



HadiDB: A lightweight, high-level scalable Python database HadiDB (hadidb) is a lightweight database written in Python, with a high level of scalability. Install HadiDB using pip installation: pipinstallhadidb User Management Create user: createuser() method to create a new user. The authentication() method authenticates the user's identity. fromhadidb.operationimportuseruser_obj=user("admin","admin")user_obj.

Python is widely used in the fields of web development, data science, machine learning, automation and scripting. 1) In web development, Django and Flask frameworks simplify the development process. 2) In the fields of data science and machine learning, NumPy, Pandas, Scikit-learn and TensorFlow libraries provide strong support. 3) In terms of automation and scripting, Python is suitable for tasks such as automated testing and system management.

You can learn basic programming concepts and skills of Python within 2 hours. 1. Learn variables and data types, 2. Master control flow (conditional statements and loops), 3. Understand the definition and use of functions, 4. Quickly get started with Python programming through simple examples and code snippets.

It is impossible to view MongoDB password directly through Navicat because it is stored as hash values. How to retrieve lost passwords: 1. Reset passwords; 2. Check configuration files (may contain hash values); 3. Check codes (may hardcode passwords).

As a data professional, you need to process large amounts of data from various sources. This can pose challenges to data management and analysis. Fortunately, two AWS services can help: AWS Glue and Amazon Athena.

MySQL database performance optimization guide In resource-intensive applications, MySQL database plays a crucial role and is responsible for managing massive transactions. However, as the scale of application expands, database performance bottlenecks often become a constraint. This article will explore a series of effective MySQL performance optimization strategies to ensure that your application remains efficient and responsive under high loads. We will combine actual cases to explain in-depth key technologies such as indexing, query optimization, database design and caching. 1. Database architecture design and optimized database architecture is the cornerstone of MySQL performance optimization. Here are some core principles: Selecting the right data type and selecting the smallest data type that meets the needs can not only save storage space, but also improve data processing speed.

The steps to start a Redis server include: Install Redis according to the operating system. Start the Redis service via redis-server (Linux/macOS) or redis-server.exe (Windows). Use the redis-cli ping (Linux/macOS) or redis-cli.exe ping (Windows) command to check the service status. Use a Redis client, such as redis-cli, Python, or Node.js, to access the server.

To read a queue from Redis, you need to get the queue name, read the elements using the LPOP command, and process the empty queue. The specific steps are as follows: Get the queue name: name it with the prefix of "queue:" such as "queue:my-queue". Use the LPOP command: Eject the element from the head of the queue and return its value, such as LPOP queue:my-queue. Processing empty queues: If the queue is empty, LPOP returns nil, and you can check whether the queue exists before reading the element.
