python基础之模块part1

模块:

  模块本质上就是一个Python程序。

  所有说是对象的,一定可以通过  对象.方法  来实现某些操作。

模块种类:

  内置模块

  第三方模块

  自定义模块

import在查找模块的顺序:内置模块---->第三方模块---->自定义模块。

后期学习网络编程(socket)跟线程进程(threading processing)的时候其实就是在学习这些模块。

time:

  在Python中时间也是一个类。

时间有三种类型:

  时间戳:时间戳表示的是从1970年1月1日00:00:00开始按秒计算的偏移量。使用time.time()查看的时间戳是一个浮点型数据

  结构化时间:元组的形式,共有九个元素

  字符串时间:方便人们阅读的格式。例如:‘2017-06-21 19:31:18‘

示例:import time
print(time.time())

print(time.localtime())

print(time.strftime("%Y-%m-%d %X"))

执行结果:
D:\Python\Python36-32\python.exe E:/Python/DAY-12/time模块.py
1498045508.7362208
time.struct_time(tm_year=2017, tm_mon=6, tm_mday=21, tm_hour=19, tm_min=45, tm_sec=8, tm_wday=2, tm_yday=172, tm_isdst=0)
2017-06-21 19:45:08

Process finished with exit code 0

三种类型的转换:

import time
print(time.localtime(time.time()))    #转换时间戳为结构化时间

print(time.mktime(time.localtime(time.time())))   #转换结构化时间为时间戳

print(time.strftime(‘%Y-%m-%d‘,time.localtime(time.time())))  #转换结构化时间为 字符串时间

print(time.strptime(‘2017-06-22‘,‘%Y-%m-%d‘))   #转换字符串时间为结构化时间

执行结果:
D:\Python\Python36-32\python.exe E:/Python/DAY-12/time模块.py
time.struct_time(tm_year=2017, tm_mon=6, tm_mday=21, tm_hour=19, tm_min=50, tm_sec=45, tm_wday=2, tm_yday=172, tm_isdst=0)
1498045845.0
2017-06-21
time.struct_time(tm_year=2017, tm_mon=6, tm_mday=22, tm_hour=0, tm_min=0, tm_sec=0, tm_wday=3, tm_yday=173, tm_isdst=-1)

Process finished with exit code 0

还有一种固定字符串结构的转换:

import time
print(time.asctime(time.localtime(3212334241)))    #结构化时间转换为固定格式字符串时间

print(time.ctime(3213213321))   #时间戳时间转换为固定格式字符串时间

执行结果:
D:\Python\Python36-32\python.exe E:/Python/DAY-12/time模块.py
Sun Oct 18 03:04:01 2071
Wed Oct 28 07:15:21 2071

Process finished with exit code 0

其他的方法:

import time
start = time.time()
time.sleep(5)     #暂停指定的时间后继续运行,单位为秒
stop = time.time()
print(‘睡了%s秒‘%(stop-start))

执行结果:
D:\Python\Python36-32\python.exe E:/Python/DAY-12/time模块.py
睡了5.000530958175659秒

Process finished with exit code 0

random:

  随机生成模块。

>>> import random
>>> random.random()      # 大于0且小于1之间的小数
0.7664338663654585

>>> random.randint(1,5)  # 大于等于1且小于等于5之间的整数

>>> random.randrange(1,3) # 大于等于1且小于3之间的整数

>>> random.choice([1,‘23‘,[4,5]])  # #1或者23或者[4,5]

>>> random.sample([1,‘23‘,[4,5]],2) # #列表元素任意2个组合
[[4, 5], ‘23‘]

>>> random.uniform(1,3) #大于1小于3的小数
1.6270147180533838

>>> item=[1,3,5,7,9]
>>> random.shuffle(item) # 打乱次序
>>> item
[5, 1, 3, 7, 9]
>>> random.shuffle(item)
>>> item
[5, 9, 7, 1, 3]

一个简单的随机验证码生成器:

import random
def valdate_code():
    ret = ‘‘
    for i in range(5):
        num = random.randint(0,9)
        a1 = chr(random.randint(97,122))
        a2 = chr(random.randint(65,90))
        s = random.choice([str(num),a1,a2])
        ret = ret+s
    return ret
print(valdate_code())

hashlib:

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

  摘要算法又称哈希算法,散列算法。通过一个函数把任意长度的数据转换为一个长度固定的数据串。

  摘要算法是单向的不可逆的。

应用:文件一致性校验,登录

示例:计算一段字符串的MD5值import hashlib

md5 = hashlib.md5()  #可以在这里的括号内进行“加盐处理”  注:加盐处理就是指在原有的内容上在加上一段字符串,提高校验值的复杂性
md5.update(‘how to use md5 in python hashlib?‘)  #update接收信息可以重叠接收
print md5.hexdigest()    #显示摘要信息

执行结果:
d26a53750bc40b38b65a520292f69306

os:

  操作系统模块。

  操作系统提供的一些接口,Python来调用。

os.getcwd() 获取当前工作目录,即当前python脚本工作的目录路径
os.chdir("dirname")  改变当前脚本工作目录;相当于shell下cd
os.curdir  返回当前目录: (‘.‘)
os.pardir  获取当前目录的父目录字符串名:(‘..‘)
os.makedirs(‘dirname1/dirname2‘)    可生成多层递归目录
os.removedirs(‘dirname1‘)    若目录为空,则删除,并递归到上一级目录,如若也为空,则删除,依此类推
os.mkdir(‘dirname‘)    生成单级目录;相当于shell中mkdir dirname
os.rmdir(‘dirname‘)    删除单级空目录,若目录不为空则无法删除,报错;相当于shell中rmdir dirname
os.listdir(‘dirname‘)    列出指定目录下的所有文件和子目录,包括隐藏文件,并以列表方式打印
os.remove()  删除一个文件
os.rename("oldname","newname")  重命名文件/目录
os.stat(‘path/filename‘)  获取文件/目录信息
os.sep    输出操作系统特定的路径分隔符,win下为"\\",Linux下为"/"
os.linesep    输出当前平台使用的行终止符,win下为"\t\n",Linux下为"\n"
os.pathsep    输出用于分割文件路径的字符串 win下为;,Linux下为:
os.name    输出字符串指示当前使用平台。win->‘nt‘; Linux->‘posix‘
os.system("bash command")  运行shell命令,直接显示
os.environ  获取系统环境变量
os.path.abspath(path)  返回path规范化的绝对路径
os.path.split(path)  将path分割成目录和文件名二元组返回
os.path.dirname(path)  返回path的目录。其实就是os.path.split(path)的第一个元素
os.path.basename(path)  返回path最后的文件名。如何path以/或\结尾,那么就会返回空值。即os.path.split(path)的第二个元素
os.path.exists(path)  如果path存在,返回True;如果path不存在,返回False
os.path.isabs(path)  如果path是绝对路径,返回True
os.path.isfile(path)  如果path是一个存在的文件,返回True。否则返回False
os.path.isdir(path)  如果path是一个存在的目录,则返回True。否则返回False
os.path.join(path1[, path2[, ...]])  将多个路径组合后返回,第一个绝对路径之前的参数将被忽略
os.path.getatime(path)  返回path所指向的文件或者目录的最后存取时间
os.path.getmtime(path)  返回path所指向的文件或者目录的最后修改时间
os.path.getsize(path) 返回path的大小
时间: 2024-12-23 14:52:42

python基础之模块part1的相关文章

python 基础之 模块

Python 基础之模块 一个模块就是一个包含了python定义和声明的文件,文件名就是模块名字加上.py的后缀. 就是一个python文件中定义好了类和方法,实现了一些功能,可以被别的python文件所调用 那么如何使用一个模块呢? 当然是使用import 模块名 这个方式加载一个模块了 ,比如:import time 如果要使用模块中的类,就是: 模块名 点儿 类 比如: import modle.Teacher 那么如果模块中的方法不知道是做什么用的怎么办呢?     两种方法:    

Python基础-----logging模块

#!/usr/bin/env python#-*- coding:utf-8 -*- ########################################################################################################################################################灵活配置日志级别,日志格式,输出位置#####################################

带你学python基础:模块和包

一.什么是模块 在我们平时的开发过程中,或多或少会用到 Python 的一些内置的功能,或者说,还会用到一些第三方的库,我们用到的这些 Python 的内置的功能,和一些第三方的库,就可以说是一些模块了. 例如,我们在读写文件的时候,我们就会用到文件操作的模块os. 是不是经常遇到呢?模块,来了! 其实,每一个 Python 脚本文件都可以被当成是一个模块. 模块以磁盘文件的形式存在.当一个模块变得过大,并且驱动了太多功能的话,就应该考虑拆一些代码出来另外建一个模块. 模块里的代码可以是一段直接

python基础--导入模块

一,import的使用1, 模块就是一组功能的集合体,我们的程序可以导入模块来复用模块中的功能一个模块就是包含了一组功能的python文件,例如demo.py 可以通过import来使用这个文件定义demo模块如下 print("导入模块") num = 1000 def read1(): print('demo模块',num) def read2(): print('demo模块') read1() def change(): global num num = 0 模块中可以包含语句

【python基础之----模块】

模块是实现某个功能的代码集合 函数式编程则完成一个功能,其他代码用来调用即可,提供了代码的重用性和代码间的耦合.而对于一个复杂的功能来,可能需要多个函数才能完成(函数又可以在不同的.py文件中),n个 .py 文件组成的代码集合就称为模块. 模块分为三种: 内置标准模块(标准库) 第三方模块(开源模块) 自定义模块 1. 自定义模块 # 单模块,且在同一目录下,建议用 import # 定义一个模块文件名字为common.py,在当前目录 def f2(): print("F2") #

#python基础学习模块:marshal 对象的序列化

#标准库地址:https://docs.python.org/2/library/marshal.html"""有时候,要把内存中一个对象持久化保存磁盘或者序列化二进制流通过网络发送到远程主机上,python有很多模块提供了序列化与反列化功能,如:marshal, pickle, cPickle等 注意: marshal并不是一个通用的模块,在某些时候它是一个不被推荐使用的模块,因为使用marshal序列化的二进制数据格式还没有文档化,在不同版本的Python中,marsha

python基础之模块二

六 logging模块 6.1 函数式简单配置 import logging #导入模块 logging.debug('debug message') #调试消息 logging.debug('info message') #导入消息 logging.debug('warning message') #警告消息 logging.error('error message') #错误消息 logging.critical('critical message') #严重信息 默认情况下python的l

python基础四(模块的导入)

一.导入模块?从模块导入时,一般使用 import sys(用sys模块举例) #这种方式导入模块,要使用这个模块其中的功能,语法为模块名称**.**功能,如print(sys.path) from sys import path #这种方式导入模块要使用模块中的功能,直接功能名即可print(sys),如果要导入该模块多个功能可以以逗号隔开 from SomeMode import * #这种方式和第二种一样只是把具体的功能名换成了*(导入所有),这种方式也有弊端,假如你导入的模块都有一个名为

【python基础】模块&包

一.模块 1.所谓模块, 就是指封装好一定功能的.py文件.如果想要使用某个模块,直接导入就行了. 2.random.py 模块名就是文件名(不包含后缀) 3.模块名的命名规则,遵循标识符的命名规则.变量,函数名,类名,模块名 二.模块的作用 1.程序开发文件比较大,都放在同一个文件中,管理维护非常不方便.拆成多个模块进行管理,方便维护. 2.模块可以增加程序的复用率. 三.模块的分类 1.程序员封装 2.python自带的模块; random, time, datetime, sys, os.