今天我们来看一看python中的常用的模块,内容有点多,我会分两天来更新这些知识

一.什么是模块

  模块就是我们把装有特定功能的代码就行归类的结果,从代码编写的单位来看我们的程序,从小到大的顺序:一条代码 < 语句块 < 代码块(函数,类) < 模块,我们目前写的所有的py文件都是模块.

  引入模块的方式:

    1.import模块

    2.from xxx import 模块

  关于这两种写法,我们后面还要继续介绍,在之前的学习中,我们已经用过了一些基本的模块了,比如,random,os,sys,collections等等,那我们目前用到的所有模块都是python内置的模块,不需要额外安装,在后面学习高级框架的内容的时候,可能需要我门自行安装一些第三方提供的模块.

二.collections模块

  collections模块主要封装了一些关于集合类的相关操作,比如我们学过的Iterable,Iterator等等,除了这些以外,collections还提供了一些除了基本数据类型以外的数据集合类型,Counter,deque,OrderDict,defaultdict,以及namedtuple

  1.Counter

    Counter是一个计数器,主要用来计数

  计算一个字符串中每个字符出现的次数

low:

s = 'alex like pig'

dic = {}
for c in s:
dic[c] = dic.get(c,0) + 1
print(dic) nb:
s = 'alex like pig'
print(Counter(s)) #获取到的结果可以像字典一样进行使用 [key]

  2.deque 双向队列

  (重点)双向队列之前需要了解两种数据结构:1.栈,2.队列

    1.栈:FIFO,先进后出 -> 墙头的砖头,老师傅做馒头

    2.队列:FIFO,先进先出 -> 买火车票排队,所有排队的场景

  由于python没有给出Stack模块,所以我们自己手动写一个粗略版本(注意,此版本有严重的并发问题)

class StackEmptyError(Exception):
pass
class StackFullError(Exception):
pass
class Stack:
def __init__(self, size):
self.index = 0
self.size = size
self.lst = [] def pop(self):
if self.index > 0:
ret = self.lst[self.index]
return ret
else:
raise StackEmptyError("stack has already empty") def push(self, el):
if self.index > self.size:
raise StackFullError("stack is full")
else:
self.lst[self.index] = el
self.index = self.index + 1 def clear(self):
self.lst.clear()
self.index = 0 def __sizeof__(self):
return len(self.lst) def max(self):
return self.size def now(self):
return self.index

  队列:python提供了queue模块,使用起来非常方便

import queue
q = queue.Queue()
q.put('李嘉诚')
q.put('张开')
q.put('张毅')
print(q)
print(q.get())
print(q.get())
print(q.get())

  注意,如果队列没有元素了,再也就拿不出来元素了,此时程序会阻塞,接下来我们来看一下deque,注意,此队列是collections中的

from collections import deque

q = deque()
q.append("张开") # 右侧添加
q.append("包贝尔")
q.appendleft("赵又廷") # 左侧添加
q.appendleft("还我高圆圆")
print(q) print(q.pop()) # 右侧删除
print(q.popleft()) # 左侧删除

  3.namedtuple 命名元组

    命名元组,顾名思义,给元组内的元素进行命名,比如,我们说(x,y)这是一个元组,同时我们还可以认为这是一个点坐标,这时我们就可以使用namedtuple对元素进行命名

from collections import namedtuple

#自定义了一个元组,如果灵性够好,这其实就是创建了一个类
nt = namedtuple('point',['x','y'])
p = nt(1,2)
print(p) print(p.x)
print(p.y)

  4.orderdict和defaultdict

    orderdict 顾名思义,字典的key默认是无序的,而OrderDict是有序的

dic = {'a':'娃哈哈','b':'薯条','c':'胡辣汤'}
print(dic) from collections import Orderdict
od = OrderDict({'a':'娃哈哈','b':'薯条','c':'胡辣汤'})
print(od)

  defaultdict:可以给字典设置默认值,当key不存在时,直接获取默认值

from collections import defaultdict

dd = defaultdict(list) # 默认值list
print(dd['娃哈哈']) # [] 当key不存在的时候. 会自动执行构造方法中传递的内容.

三.time时间模块(重点)

  时间模块是我们要熟记的,到后面写程序的时候经常能用到,比如,如何计算时间差,如何按照客户的要求展示时间,等等

import time
print(time,time())

  此时我们已经获取到了系统时间,但是这个时间...看不懂,怎么办?需要对时间进行格式化,那这样就引出了另一种时间的格式,在python中时间分成三种表现形式:

    1.时间戳(timestamp),时间戳使用的是从1970年01月01日00点00分00秒到现在一共经过了多少秒...使用float来表示

    2.格式化时间(strftime),这个时间可以根据我们的需要对时间进行任意的格式化

    3.结构化时间(struct_time),这个时间主要可以把时间进行分类划分,比如1970年01月01日00点00分00秒,这个时间可以被细分为年,月,日...一大推东西

  时间戳我们已经见过了就是time.time(),一般我们不会把这样的时间显示给客户,那就需要对时间进行格式化操作

s = time.strftime('%Y-%m-%d %H:%M:%S')  #必须记住
print(s)

  日期格式化的标准:

%y 两位数的年份表示(00-99)
%Y 四位数的年份表示(000-9999)
%m 月份(01-12)
%d 月内中的一天(0-31)
%H 24小时制小时数(0-23)
%I 12小时制小时数(01-12)
%M 分钟数(00=59)
%S 秒(00-59)
%a 本地简化星期名称
%A 本地完整星期名称
%b 本地简化的月份名称
%B 本地完整的月份名称
%c 本地相应的日期表示和时间表示
%j 年内的一天(001-366)
%p 本地A.M.或P.M.的等价符
%U 一年中的星期数(00-53)星期天为星期的开始
%w 星期(0-6),星期天为星期的开始
%W 一年中的星期数(00-53)星期一为星期的开始
%x 本地相应的日期表示
%X 本地相应的时间表示
%Z 当前时区的名称
%% %号本身

  看一下结构化时间:

print(time.localtime())
结果:
time.struct_time(tm_year=2017, tm_mon=05, tm_mday=8, tm_hour=10, tm_min=24,
tm_sec=42, tm_wday=0, tm_yday=126, tm_isdst=0)

  好了,先在看到的都是当前系统时间, 那如果碰到时间转换呢? 比如我们的数据库中存储了这样一个时间: 1888888888. 如何显示成xxxx年xx月xx日,那时间的转化必须要记住: 所有的转化都要通过结构化时间来转化. 

t = time.localtime(1888888888) # 结构化时间
s = time.strftime("%Y-%m-%d %H:%M:%S", t) # 格式化这个时间
print(s)

  那如果说, 我让用户输入一个时间, 怎么把它转化成我们数据库存储的时间戳呢? 还是要用到结构化时间

s = "2020-10-01 12:18:12"
t = time.strptime(s, "%Y-%m-%d %H:%M:%S") # 转化成结构时间
print(time.mktime(t)) # 转换成时间戳

  以上两段代码必须记住. 

  计算时间差:

import time
true_time=time.mktime(time.strptime('2017-09-11 08:30:00','%Y-%m-%d
%H:%M:%S'))
time_now=time.mktime(time.strptime('2017-09-12 11:00:00','%Y-%m-%d
%H:%M:%S'))
dif_time=time_now-true_time
struct_time=time.localtime(dif_time)
print(struct_time)
print('过去了%d年%d月%d天%d小时%d分钟%d秒'%(struct_time.tm_year-
1970,struct_time.tm_mon-1,struct_time.tm_mday-1,struct_time.tm_hour,
struct_time.tm_min,struct_time.tm_sec))

四.random模块

  所有关于随机相关的内容都在random模块

import random

print(random.random()) # 0-1小数
print(random.uniform(3, 10)) # 3-10小数 print(random.randint(1, 10)) # 1-10整数 [1, 10]
print(random.randrange(1, 10, 2)) # 1-10奇数 [1,10) print(random.choice([1, '周杰伦', ["盖伦", "胡辣汤"]])) # 1或者23或者[4,5])
print(random.sample([1, '23', [4, 5]], 2)) # 列表元素任意2个组合 lst = [1, 2, 3, 4, 5, 6, 7, 8]
random.shuffle(lst) # 随机打乱顺序
print(lst)

  好了,今天就到这里,明天继续!!!

Python-常用模块1的更多相关文章

  1. Python常用模块之sys

    Python常用模块之sys sys模块提供了一系列有关Python运行环境的变量和函数. 常见用法 sys.argv 可以用sys.argv获取当前正在执行的命令行参数的参数列表(list). 变量 ...

  2. Python常用模块中常用内置函数的具体介绍

    Python作为计算机语言中常用的语言,它具有十分强大的功能,但是你知道Python常用模块I的内置模块中常用内置函数都包括哪些具体的函数吗?以下的文章就是对Python常用模块I的内置模块的常用内置 ...

  3. python——常用模块2

    python--常用模块2 1 logging模块 1.1 函数式简单配置 import logging logging.debug("debug message") loggin ...

  4. python——常用模块

    python--常用模块 1 什么是模块: 模块就是py文件 2 import time #导入时间模块 在Python中,通常有这三种方式来表示时间:时间戳.元组(struct_time).格式化的 ...

  5. Python常用模块——目录

    Python常用模块学习 Python模块和包 Python常用模块time & datetime &random 模块 Python常用模块os & sys & sh ...

  6. python 常用模块之random,os,sys 模块

    python 常用模块random,os,sys 模块 python全栈开发OS模块,Random模块,sys模块 OS模块 os模块是与操作系统交互的一个接口,常见的函数以及用法见一下代码: #OS ...

  7. python常用模块之时间模块

    python常用模块之时间模块 python全栈开发时间模块 上次的博客link:http://futuretechx.com/python-collections/ 接着上次的继续学习: 时间模块 ...

  8. python常用模块之subprocess

    python常用模块之subprocess python2有个模块commands,执行命令的模块,在python3中已经废弃,使用subprocess模块来替代commands. 介绍一下:comm ...

  9. python常用模块之string

    python常用模块string模块,该模块可以帮我们获取字母.数字.特殊符号. import string #打印所有的小写字母 print(string.ascii_lowercase) #打印所 ...

  10. python常用模块-调用系统命令模块(subprocess)

    python常用模块-调用系统命令模块(subprocess) 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. subproces基本上就是为了取代os.system和os.spaw ...

随机推荐

  1. flink学习笔记:DataSream API

    本文为<Flink大数据项目实战>学习笔记,想通过视频系统学习Flink这个最火爆的大数据计算框架的同学,推荐学习课程: Flink大数据项目实战:http://t.cn/EJtKhaz ...

  2. P5030 长脖子鹿放置 最小割

    $ \color{#0066ff}{ 题目描述 }$ 如图所示,西洋棋的"长脖子鹿",类似于中国象棋的马,但按照"目"字攻击,且没有中国象棋"别马腿& ...

  3. 用 gdb 和 qemu 调试 grub

    因为qemu内置了gdbserver,所以我们可以用gdb调试qemu虚拟机上执行的代码,而且不受客户机系统限制. 以下内容是我调试 grub 0.97 时的一份笔记. 准备 qemu, gdb,以及 ...

  4. PowerBuilder中新建PBL

    首先需要打开工作区间workspace , 然后选择你的第一个根pbl文件. 如图所示: 选择WorkSpace下的第一个application.PBT文件,然后单击鼠标右键,选择属性Properti ...

  5. 基础篇:3)规范化:3d制图总章

    本章目的:明确3d绘图也有相应的准则,遵守者方有相应的进阶之路. 1.建模目标:拥有自己的建模思想 学习完成3d制图,最直接的评价标准就是--拥有自己的建模思想. 其表现为: 1)建模思路明确,能独立 ...

  6. leetcode 191:统计1的个数;5 最长回文串;54,59 蛇形矩阵

    class Solution { public: int hammingWeight(uint32_t n) { ; //统计次数 ){ n &= (n-); //每次消掉一个1 k++; / ...

  7. 压缩jar包

    1.   下载所要压缩 jar 包的源代码 2.   找到所有需要导入的类,  比如: import org.bouncycastle.util.io.pem.PemObject; import or ...

  8. 4.nginx动静分离

    动静分离,就是将css.js.jpg等静态资源和jsp等动态资源分开处理,以此提高服务器响应速度,提高性能. 核心就是区分动态和静态资源 图片转自:https://www.cnblogs.com/xi ...

  9. Tomcat部署项目的三种方式

    目录 1.下载 Tomcat 服务器 2.启动并部署 Tomcat 服务器 3.Tomcat 的目录结构 4.部署项目的第一种方法(项目直接放入 webapps 目录中) 5.部署项目的第二种方法(修 ...

  10. Docker 镜像加速

    通过 Docker 官方镜像加速,中国区用户能够快速访问最流行的 Docker 镜像.该镜像托管于中国大陆,本地用户现在将会享受到更快的下载速度和更强的稳定性,从而能够更敏捷地开发和交付 Docker ...