挑战30天学完Python:Day20 PIP 包管理

2024-02-25 03:44

本文主要是介绍挑战30天学完Python:Day20 PIP 包管理,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

🎉 本系列为Python基础学习,原稿来源于 30-Days-Of-Python 英文项目,大奇主要是对其本地化翻译、逐条验证和补充,想通过30天完成正儿八经的系统化实践。此系列适合零基础同学,或仅了解Python一点知识,但又没有系统学习的使用者。总之如果你想提升自己的Python技能,欢迎加入《挑战30天学完Python》

  • 📘 Day 20
    • Python PIP 包管理
      • 什么是 PIP ?
      • 安装 PIP
      • 使用pip安装包
      • 卸载包
      • 查看包列表
      • 查看包信息
      • PIP Freeze
      • 从WEB中读取数据
      • 创建包
      • 关于更多包的信息

📘 Day 20

Python PIP 包管理

什么是 PIP ?

PIP是Python第三方库管理器,我们可以通过 pip 来安装不同的Python包。
包是一个Python模块,可以包含一个或多个模块或其他包。即可以安装到应用程序中的一个或多个模块就是一个包。
在实际的编程中,我们不必去编写每一个实用程序,很多有别人已经封装好的,我们可以导入到程序中直接使用。

安装 PIP

如果你是通过程序安装的python环境,那么默认pip已经在其中了,让我们打开终端查看:

>pip --version
pip 21.1.1 from c:\programdata\python38\lib\site-packages\pip (python 3.8)

如你所见, 我当前使用的 pip 版本是 21.1.1。如果你到其他版本数字都证明,pip已经被安装,可以正常使用。

让我们检查一下Python社区中用于不同编码的一些包。注意,这些演示只是想让你知道有很多包可以用于不同的应用程序,并不展开讲解。

使用pip安装包

让我们首先来安装一个叫 numpy 的包。它是机器学习和数据科学社区中最受欢迎的软件包之一。

NumPy是使用Python进行科学计算的基本包。它还包括:

  • 一个强大的n维数组对象
  • 复杂的(广播)功能
  • 集成C/ c++和Fortran代码的工具
  • 有用的线性代数\随机数等功能
> pip install numpy
Successfully installed numpy-1.24.2

当你看到提示successfully的字样表示安装成功,事实上可能你本地已经有了此包,你可以通过 pip uninstall numpy 先卸载,然后再体验安装过程。

包numpy安装成功后,让我们看下如何使用:

> python
Python 3.8.10 (tags/v3.8.10:3d8993a, May  3 2021, 11:48:03) [MSC v.1928 64 bit (AMD64)] on win32
Type "help", "copyright", "credits" or "license" for more information.
>>> import numpy
>>> numpy.version.version
'1.24.2'
>>> list = [1,2,3,4,5]
>>> np_arr = numpy.array(list)
>>> np_arr
array([1, 2, 3, 4, 5])
>>> len(np_arr)
5
>>> np_arr * 2
array([ 2,  4,  6,  8, 10])
>>> np_arr + 2
array([3, 4, 5, 6, 7])
>>>

Pandas是一个BSD许可开放源码库,为Python编程语言提供高性能、易于使用的数据结构和数据分析工具。让我们安装比numpy更高级的 pandas

> pip install pandas

终端上练习导入和使用

> python>>> import pandas as pd
>>> df = pd.Series(0, index=['1', '2', '3', '4'])
>>> print(df)
1    0
2    0
3    0
4    0
dtype: int64

本节不细化关于numpy或pandas内置函数功能,在这里我们仅尝试学习如何安装软件包以及如何导入它们。如果需要,我们将在其他部分讨论不同的包。

接下来,让我们导入一个网页浏览器模块,它可以帮助我们打开任何网站。我们不需要安装这个模块,因为它已经在Python 3中默认安装了。例如,如果你想在任何时间打开任意数量的网站,或者如果你想安排一些事情,你可以利用 webbrowser 模块。

import webbrowser # url列表
url_lists = ['http://www.python.org','https://github.com/QiCodeCN'
]# 浏览器通过标签页打开
for url in url_lists:webbrowser.open_new_tab(url)

卸载包

如果您希望不再保留已安装的包,您可以使用以下命令删除它们。

pip uninstall packagename

查看包列表

查看我们机器上已安装的包。我们可以用 pip list 命令。

pip listPackage               Version
--------------------- -----------
anyascii              0.3.1
appdirs               1.4.4
... 省略 ...

查看包信息

查看包的详细信息,可以使用show + 包名

pip show packagename

比如查看上边安装好的pandas包详细

>pip show pandas
Name: pandas
Version: 1.5.2
Summary: Powerful data structures for data analysis, time series, and statistics
Home-page: https://pandas.pydata.org
Author: The Pandas Development Team
Author-email: pandas-dev@python.org
License: BSD-3-Clause
Location: c:\programdata\python38\lib\site-packages
Requires: python-dateutil, numpy, pytz
Required-by: TTS

上边是列了基本的信息,如果你想看更多信息,请加上参数 --verbose

>pip show --verbose pandas
Name: pandas
Version: 1.5.2
Summary: Powerful data structures for data analysis, time series, and statistics
Home-page: https://pandas.pydata.org
Author: The Pandas Development Team
Author-email: pandas-dev@python.org
License: BSD-3-Clause
Location: c:\programdata\python38\lib\site-packages
Requires: pytz, python-dateutil, numpy
Required-by: TTS
Metadata-Version: 2.1
Installer: pip
Classifiers:Development Status :: 5 - Production/StableEnvironment :: ConsoleIntended Audience :: Science/ResearchLicense :: OSI Approved :: BSD LicenseOperating System :: OS IndependentProgramming Language :: CythonProgramming Language :: PythonProgramming Language :: Python :: 3Programming Language :: Python :: 3 :: OnlyProgramming Language :: Python :: 3.8Programming Language :: Python :: 3.9Programming Language :: Python :: 3.10Programming Language :: Python :: 3.11Topic :: Scientific/Engineering
Entry-points:[pandas_plotting_backends]matplotlib = pandas:plotting._matplotlib

PIP Freeze

当我们代码稳定稳定后,通常代码迁移时候,需要获取Python项目依赖包的安装列表,以便别人能够快速安装。这个列表要包括需要安装什么包、以及包的版本。通常我们输出到 requirements.txt 文件中。

> pip freeze > requirements.txt

注意:freeze默认是python环境所有包,如果想仅保持单独项目的,尽量使用虚拟环境。下边命令演示了如何根据requirements一键安装。

> pip install -r requirements.txt

从WEB中读取数据

到目前为止,您已经熟悉了如何读取或写入本地计算机上的文件。但有时,我们想从一个网站读取信息,比如从url或API。

API是应用程序接口的缩写。它是一种在服务器之间交换结构化数据的方法,主要是为json数据。要打开一个网络连接,我们需要一个名为 requests 的包——它允许打开一个网络连接并实现CRUD(创建、读取、更新和删除)操作。在本节中,我们将只讨论CRUD的读取和获取部分。

同样首先安装 requests 模块包:

> pip install requests

我们可以了解它的 get, status_code, headers, textjson 方法:

  • get():打开一个网络并从url中获取数据-它返回一个响应对象
  • status_code:在我们获取数据后,我们可以检查操作的状态(成功,错误等)
  • headers:检查头信息类型
  • text:从获取的响应对象中提取文本
  • json:提取json数据

让我们读取一个txt文件从这个网址中 https://www.w3.org/TR/WD-html40-970708/html40.txt

import requests # 导入模块url = 'https://www.w3.org/TR/WD-html40-970708/html40.txt' # 定义要读取的地址变量response = requests.get(url) # 请求地址并获取返回数据
print(response)
print(response.status_code) # 打印状态, success:200
print(response.headers)     # 头信息
print(response.text) # 查看所返回的数据文本 注意如果地址无法访问时候内容是404
  • 让我们从API中读取。API是应用程序接口的缩写。它是一种在服务器之间交换结构数据的方法,主要是json数据。
import requests
url = 'https://v0.yiketianqi.com/api?unescape=1&version=v91&appid=43656176&appsecret=I42og6Lm&ext=&cityid=&city='  # 国内可访问天气接口
response = requests.get(url) 
print(response) 
print(response.status_code) 
weather = response.json() 
print(weather)

两个请求中最后一个直接可以获取json对象。但如果不是JSON数据类型返回,我们通常都使用text获取,然后再根据需要进行转换或者处理。

创建包

我们根据一些标准将大量的文件组织在不同的文件夹和子文件夹中,这样我们就可以很容易地找到和管理它们。如你所知,一个模块可以包含多个对象,比如类、函数等。一个包可以包含一个或多个相关模块。包实际上是一个包含一个或多个模块文件的文件夹。因此,如果我们开发的是一个通用的项目,我们可以自己的包用于自己或者他人使用。让我们以创建一个名为 mypackage 的包为例,使用以下步骤:、

  1. 30DaysOfPython-zh_CN 文件夹中创建一个名为 mypacakge 的新文件夹
  2. 在 mypacakge 文件夹中创建一个空的 init.py 文件
  3. 使用以下代码创建模块arithtic .py和greet.py
# mypackage/arithmetics.py
# arithmetics.py
def add_numbers(*args):total = 0for num in args:total += numreturn totaldef subtract(a, b):return (a - b)def multiple(a, b):return a * bdef division(a, b):return a / bdef remainder(a, b):return a % bdef power(a, b):return a ** b
# mypackage/greet.py
# greet.py
def greet_person(firstname, lastname):return f'{firstname} {lastname}, welcome to 30DaysOfPython Challenge!'

最终包的文件夹结构应该是这样的:

─ mypackage├── __init__.py├── arithmetic.py└── greet.py

现在让我们打开python交互式shell并尝试使用自定义包:

30DaysOfPython-zh-CN > python>>> from mypackage import arithmetics
>>> arithmetics.add_numbers(1, 2, 3, 5)
11
>>> arithmetics.subtract(5, 3)
2
>>> arithmetics.multiple(5, 3)
15
>>> arithmetics.division(5, 3)
1.6666666666666667
>>> arithmetics.remainder(5, 3)
2
>>> arithmetics.power(5, 3)
125
>>> from mypackage import greet
>>> greet.greet_person('Mega', 'Qi')
'Mega Qi, welcome to 30DaysOfPython Challenge!'
>>>

从上边的例子中可以看出,我们的包可以正常的工作。文件夹包含一个名为 init 空文件(py的特殊文件——它存储包的内容)。如果我们将 init.py 放在包文件夹中,python会将其识别为包。init.py 从其模块中公开指定的资源,以便导入到其他python文件中。一个空的__init__.py文件使所有函数在导入包时都可用。总而言之 init.py 对于被 Python 识别为包的文件夹是必不可少存在。

关于更多包的信息

  • 数据库

    • SQLAlchemy or SQLObject - 对几个不同数据库系统的面向对象访问
      • pip install SQLAlchemy
  • Web开发

    • Django - 高级web框架
      • pip install django
    • Flask - 基于Werkzeug的Python微框架
      • pip install flask
  • HTML爬虫

    • Beautiful Soup - 是一个HTML/XML的解析器,主要的功能也是如何解析和提取HTML/XML数据。
      • pip install beautifulsoup4
    • PyQuery - 在Python中实现jQuery;显然比BeautifulSoup快。
  • XML 语言

    • ElementTree - Element类型是一种简单但灵活的容器对象,用于在内存中存储层次数据结构,例如简化的XML信息集。注意:Python 2.5及以上版本在标准库中带有ElementTree
  • GUI桌面程序

    • PyQt - 跨平台的桌面程序框架
    • TkInter - 传统的Python用户界面工具包(内置)
  • 数据分析,数据科学和机器学习

    • Numpy: Numpy(numeric python) 被称为 python 中最受欢迎的机器学习库之一
    • Pandas: 作为数据分析、数据科学和机器学习库,提供高级数据结构和各种各样的分析工具。
    • SciPy: 是一个面向应用程序开发人员和工程师的机器学习库。SciPy库包含优化、线性代数、集成、图像处理和统计模块。
    • Scikit-Learn: 针对Python 编程语言的免费软件机器学习库。通常被认为是处理复杂数据的最佳库之一
    • TensorFlow: 谷歌建立了一个机器学习库
    • Keras: 是一个 Python深度学习框架。
  • Network:

    • requests: 一个可以发送请求到服务器(GET, POST, DELETE, PUT)的包
      • pip install requests

🌕 你一直在进步,到目前为止你已经成功学习20节内容。真棒!

受限制于练习的海外地址可能服务访问,本篇内容没有明确的练习题,请选择通过搜索引擎学习和练习一些库。

🎉 CONGRATULATIONS ! 🎉

<< Day 19 | Day 21 >>

这篇关于挑战30天学完Python:Day20 PIP 包管理的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


原文地址:
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.chinasem.cn/article/744294

相关文章

使用Python删除Excel中的行列和单元格示例详解

《使用Python删除Excel中的行列和单元格示例详解》在处理Excel数据时,删除不需要的行、列或单元格是一项常见且必要的操作,本文将使用Python脚本实现对Excel表格的高效自动化处理,感兴... 目录开发环境准备使用 python 删除 Excphpel 表格中的行删除特定行删除空白行删除含指定

Spring Boot集成Druid实现数据源管理与监控的详细步骤

《SpringBoot集成Druid实现数据源管理与监控的详细步骤》本文介绍如何在SpringBoot项目中集成Druid数据库连接池,包括环境搭建、Maven依赖配置、SpringBoot配置文件... 目录1. 引言1.1 环境准备1.2 Druid介绍2. 配置Druid连接池3. 查看Druid监控

Python通用唯一标识符模块uuid使用案例详解

《Python通用唯一标识符模块uuid使用案例详解》Pythonuuid模块用于生成128位全局唯一标识符,支持UUID1-5版本,适用于分布式系统、数据库主键等场景,需注意隐私、碰撞概率及存储优... 目录简介核心功能1. UUID版本2. UUID属性3. 命名空间使用场景1. 生成唯一标识符2. 数

Python办公自动化实战之打造智能邮件发送工具

《Python办公自动化实战之打造智能邮件发送工具》在数字化办公场景中,邮件自动化是提升工作效率的关键技能,本文将演示如何使用Python的smtplib和email库构建一个支持图文混排,多附件,多... 目录前言一、基础配置:搭建邮件发送框架1.1 邮箱服务准备1.2 核心库导入1.3 基础发送函数二、

Python包管理工具pip的升级指南

《Python包管理工具pip的升级指南》本文全面探讨Python包管理工具pip的升级策略,从基础升级方法到高级技巧,涵盖不同操作系统环境下的最佳实践,我们将深入分析pip的工作原理,介绍多种升级方... 目录1. 背景介绍1.1 目的和范围1.2 预期读者1.3 文档结构概述1.4 术语表1.4.1 核

基于Python实现一个图片拆分工具

《基于Python实现一个图片拆分工具》这篇文章主要为大家详细介绍了如何基于Python实现一个图片拆分工具,可以根据需要的行数和列数进行拆分,感兴趣的小伙伴可以跟随小编一起学习一下... 简单介绍先自己选择输入的图片,默认是输出到项目文件夹中,可以自己选择其他的文件夹,选择需要拆分的行数和列数,可以通过

Python中反转字符串的常见方法小结

《Python中反转字符串的常见方法小结》在Python中,字符串对象没有内置的反转方法,然而,在实际开发中,我们经常会遇到需要反转字符串的场景,比如处理回文字符串、文本加密等,因此,掌握如何在Pyt... 目录python中反转字符串的方法技术背景实现步骤1. 使用切片2. 使用 reversed() 函

Python中将嵌套列表扁平化的多种实现方法

《Python中将嵌套列表扁平化的多种实现方法》在Python编程中,我们常常会遇到需要将嵌套列表(即列表中包含列表)转换为一个一维的扁平列表的需求,本文将给大家介绍了多种实现这一目标的方法,需要的朋... 目录python中将嵌套列表扁平化的方法技术背景实现步骤1. 使用嵌套列表推导式2. 使用itert

使用Docker构建Python Flask程序的详细教程

《使用Docker构建PythonFlask程序的详细教程》在当今的软件开发领域,容器化技术正变得越来越流行,而Docker无疑是其中的佼佼者,本文我们就来聊聊如何使用Docker构建一个简单的Py... 目录引言一、准备工作二、创建 Flask 应用程序三、创建 dockerfile四、构建 Docker

Python使用vllm处理多模态数据的预处理技巧

《Python使用vllm处理多模态数据的预处理技巧》本文深入探讨了在Python环境下使用vLLM处理多模态数据的预处理技巧,我们将从基础概念出发,详细讲解文本、图像、音频等多模态数据的预处理方法,... 目录1. 背景介绍1.1 目的和范围1.2 预期读者1.3 文档结构概述1.4 术语表1.4.1 核