python内建模块

2024-04-11 22:08
文章标签 python 模块 内建

本文主要是介绍python内建模块,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

datetime

from datetime import datetime, timedelta, timezone#测试datetime
now = datetime.now()
#创建时间by数字
dt = datetime(1970, 2, 28, 20, 10, 50)
#创建时间by string
dt = datetime.strptime('2015/06/01 18:19:59', '%Y/%m/%d %H:%M:%S')
#时间戳
timestamp = dt.timestamp() #5055050.0 单位s,小数点后表示ms
#创建时间by时间戳
dt = datetime.fromtimestamp(timestamp)#时间运算
print(now + timedelta(hours=10))
print(now + timedelta(days=2, hours=10))

collections

nametuple

namedtuple是一个函数,它用来创建一个自定义的tuple对象,并且规定了tuple元素的个数,并可以用属性而不是索引来引用tuple的某个元素。

# nametuple, 一个最精简的类实现
Point = namedtuple('Point', ['x','y'])
p = Point(1, 2)
print('x=', p.x, 'y=', p.y)

deque

deque是为了高效实现插入和删除操作的双向列表,适合用于队列和栈

# deque, 双向列表
q = deque(['a','b','c'])
q.append('x') #在尾部插入'x'
q.appendleft('y') #在头部插入'y'
q.popleft() #删除最左边一个item

defaultdict

使用dict时,如果引用的Key不存在,就会抛出KeyError。如果希望key不存在时,返回一个默认值,就可以用defaultdict

# defaultdict, key不存在时,返回一个默认值
dd = defaultdict(lambda : 'N/A')
dd['key1'] = 'abc'
print('dd key1=', dd['key1'], 'dd key2=', dd['key2'])

OrderedDict

使用dict时,Key是无序的。在对dict做迭代时,我们无法确定Key的顺序。
如果要保持Key的顺序,可以用OrderedDict
注意,OrderedDict的Key会按照插入的顺序排列,不是Key本身排序:

# OrderedDict, 有序的dict
d = dict([('a', 1), ('b', 2), ('c', 3)])
print('d=', d)
od = OrderedDict([('a', 1), ('b', 2), ('c', 3)])
print('od=', od)

ChainMap

ChainMap可以把一组dict串起来并组成一个逻辑上的dictChainMap本身也是一个dict,但是查找的时候,会按照顺序在内部的dict依次查找。

default = {'color':'red', 'user':'guest'}
args = {'key':'123345', 'color':'green'}combined = ChainMap(args, default)print('color=%s' % combined['color'])
print('user=%s' % combined['user'])

base64

Base64编码会把3字节的二进制数据编码为4字节的文本数据,长度增加33%,好处是编码后的文本数据可以在邮件正文、网页等直接显示。

如果要编码的二进制数据不是3的倍数,最后会剩下1个或2个字节怎么办?Base64\x00字节在末尾补足后,再在编码的末尾加上1个或2个=号,表示补了多少字节,解码的时候,会自动去掉。

# 字节码在python中表示,前面要加b,例如 b'abcd'
enc = base64.b64encode(b'abcd')
dec = base64.b64decode(b'YWJjZA==')
enc = base64.b64encode(b'i\xb7\x1d\xfb\xef\xff')
#由于标准的Base64编码后可能出现字符+和/,在URL中就不能直接作为参数,
#所以又有一种"url safe"的base64编码,其实就是把字符+和/分别变成-和_
enc = base64.urlsafe_b64encode(b'i\xb7\x1d\xfb\xef\xff')

struct

struct用来解决bytes其他二进制数据类型的转换。
方法,调用struct.pack('>I', 10240099) 返回是一个tuple

规则:
>表示字节顺序是big-endian,也就是网络序
I表示4字节无符号整数。H 2字节无符号整数。c表示char
i表示4字节有符号整数。h 2字节无符号整数。

# -*- coding: utf-8 -*-
struct.unpack('>IH', b'\xf0\xf0\xf0\xf0\x80\x80')
# 返回(4042322160, 32896)

hashlib

hashlib提供了常见的摘要算法,如MD5SHA1等等。

import hashlib#md5的使用
#MD5是最常见的摘要算法,速度很快,生成结果是固定的128 bit字节,通常用一个32位的16进制字符串表示。md5 = hashlib.md5()
md5.update('how to use md5 in '.encode('utf-8'))
md5.update('python hashlib'.encode('utf-8'))
digest = md5.hexdigest()
print('md5 digest=', digest)#sha1的使用
#SHA1的结果是160 bit字节,通常用一个40位的16进制字符串表示
#另外,还有sha256, sha512
sha1 = hashlib.sha1()
sha1.update('how to use sha1 in python hashlib'.encode('utf-8'))
digest = sha1.hexdigest()
print('sha1 digest=', digest)

itertools

itertools提供了非常有用的用于操作迭代对象的函数。

import itertools# count 创建一个无限的迭代器,用于数字,第一参数start,第二个参数step默认1
natuals = itertools.count(1, 2)
for n in natuals:print(n)if(n > 10):break# takewhile表示取出一部分
ns = itertools.takewhile(lambda x: x<=20, natuals)
print(list(ns))print(type(natuals))# cycle 创建一个无限循环序列, 参数是一个iterable
cs = itertools.cycle('abc')
cnt = 0
for c in cs:print(c)cnt += 1if cnt > 10:break
print(type(cs))# repeat 创建一个不断重复的序列,第二个参数表示count,不指定则无限
ns = itertools.repeat('ab', 3)
for n in ns:print(n)# chain 把一组迭代对象串联起来
for c in itertools.chain('abc', 'XYZ', '123'):print(c)# groupby 把迭代器中相邻的重复元素挑出来
for key, group in itertools.groupby('aaaaAAAbbbBB'):print(key, list(group))

参考资料

廖雪峰python教程

这篇关于python内建模块的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/895309

相关文章

python: 多模块(.py)中全局变量的导入

文章目录 global关键字可变类型和不可变类型数据的内存地址单模块(单个py文件)的全局变量示例总结 多模块(多个py文件)的全局变量from x import x导入全局变量示例 import x导入全局变量示例 总结 global关键字 global 的作用范围是模块(.py)级别: 当你在一个模块(文件)中使用 global 声明变量时,这个变量只在该模块的全局命名空

深入探索协同过滤:从原理到推荐模块案例

文章目录 前言一、协同过滤1. 基于用户的协同过滤(UserCF)2. 基于物品的协同过滤(ItemCF)3. 相似度计算方法 二、相似度计算方法1. 欧氏距离2. 皮尔逊相关系数3. 杰卡德相似系数4. 余弦相似度 三、推荐模块案例1.基于文章的协同过滤推荐功能2.基于用户的协同过滤推荐功能 前言     在信息过载的时代,推荐系统成为连接用户与内容的桥梁。本文聚焦于

【Python编程】Linux创建虚拟环境并配置与notebook相连接

1.创建 使用 venv 创建虚拟环境。例如,在当前目录下创建一个名为 myenv 的虚拟环境: python3 -m venv myenv 2.激活 激活虚拟环境使其成为当前终端会话的活动环境。运行: source myenv/bin/activate 3.与notebook连接 在虚拟环境中,使用 pip 安装 Jupyter 和 ipykernel: pip instal

【机器学习】高斯过程的基本概念和应用领域以及在python中的实例

引言 高斯过程(Gaussian Process,简称GP)是一种概率模型,用于描述一组随机变量的联合概率分布,其中任何一个有限维度的子集都具有高斯分布 文章目录 引言一、高斯过程1.1 基本定义1.1.1 随机过程1.1.2 高斯分布 1.2 高斯过程的特性1.2.1 联合高斯性1.2.2 均值函数1.2.3 协方差函数(或核函数) 1.3 核函数1.4 高斯过程回归(Gauss

【学习笔记】 陈强-机器学习-Python-Ch15 人工神经网络(1)sklearn

系列文章目录 监督学习:参数方法 【学习笔记】 陈强-机器学习-Python-Ch4 线性回归 【学习笔记】 陈强-机器学习-Python-Ch5 逻辑回归 【课后题练习】 陈强-机器学习-Python-Ch5 逻辑回归(SAheart.csv) 【学习笔记】 陈强-机器学习-Python-Ch6 多项逻辑回归 【学习笔记 及 课后题练习】 陈强-机器学习-Python-Ch7 判别分析 【学

nudepy,一个有趣的 Python 库!

更多资料获取 📚 个人网站:ipengtao.com 大家好,今天为大家分享一个有趣的 Python 库 - nudepy。 Github地址:https://github.com/hhatto/nude.py 在图像处理和计算机视觉应用中,检测图像中的不适当内容(例如裸露图像)是一个重要的任务。nudepy 是一个基于 Python 的库,专门用于检测图像中的不适当内容。该

pip-tools:打造可重复、可控的 Python 开发环境,解决依赖关系,让代码更稳定

在 Python 开发中,管理依赖关系是一项繁琐且容易出错的任务。手动更新依赖版本、处理冲突、确保一致性等等,都可能让开发者感到头疼。而 pip-tools 为开发者提供了一套稳定可靠的解决方案。 什么是 pip-tools? pip-tools 是一组命令行工具,旨在简化 Python 依赖关系的管理,确保项目环境的稳定性和可重复性。它主要包含两个核心工具:pip-compile 和 pip

HTML提交表单给python

python 代码 from flask import Flask, request, render_template, redirect, url_forapp = Flask(__name__)@app.route('/')def form():# 渲染表单页面return render_template('./index.html')@app.route('/submit_form',

Jenkins构建Maven聚合工程,指定构建子模块

一、设置单独编译构建子模块 配置: 1、Root POM指向父pom.xml 2、Goals and options指定构建模块的参数: mvn -pl project1/project1-son -am clean package 单独构建project1-son项目以及它所依赖的其它项目。 说明: mvn clean package -pl 父级模块名/子模块名 -am参数

寻迹模块TCRT5000的应用原理和功能实现(基于STM32)

目录 概述 1 认识TCRT5000 1.1 模块介绍 1.2 电气特性 2 系统应用 2.1 系统架构 2.2 STM32Cube创建工程 3 功能实现 3.1 代码实现 3.2 源代码文件 4 功能测试 4.1 检测黑线状态 4.2 未检测黑线状态 概述 本文主要介绍TCRT5000模块的使用原理,包括该模块的硬件实现方式,电路实现原理,还使用STM32类