模块

模块(module)

为了编写方便维护的代码,可以把不同功能的代码分组,保存在不同的文件里。

在python种,一个.py文件就可以被称为一个模块。

即:

  • 包含相应功能的函数以及变量,py则以’.py’为后缀名;
  • 模块可以被其他的程序引用,以使用该模块所对应的函数或者变量。

使用模块的优点:

  • 提高代码的可维护性
  • 提高代码的复用性
  • 可以引入很多功能的模块
    • 标准库模块
    • 第三方模块
    • 自定义模块
  • 避免变量名重复(作用域)

python中导入模块的常用方式

  • import 模块名
  • import 模块名 as 新名称
  • from 模块名 import 函数名

区别

  • import 模块名和import 模块名 as 新名称

    • 会导入整个模块
    • 如果我们需要使用某个函数,必须以’‘模块名.函数名()’‘的形式来调用相应的函数。这种方法可以更有利于代码的可读性(优先推荐的方法)
    • import 模块名 as 新名称;重新命名导入的模块,通常使模块名称简洁,方便使用。
  • from 模块名 import 函数名

    • 只导入了某一函数,而不是一整个模块
    • 可以直接函数名去调用函数,而无需在函数名称前加模块名称
    • 可能会造成函数名冲突,引发错误。

import …

import … as …

from … import 函数

import os
import random as rd
from math import exp

print(os.listdir())
print(rd.randint(10, 100))
print(exp(10))
#输出
['.idea', '1.py', '2.py', '3.py', '3.txt', '4.py', '4.txt', '5.py', '7.py', 'dictUser1.txt', 'GreenFlowerPorcelain.txt', 'test.txt', 'test1.py', 'test1.txt', 'test4', 'venv', 'work-1.py', 'work-2.py', 'work-3.py', 'work-4.py', 'work-5.py', 'work-6.py', 'work-7.py', 'yh.py', '浙江大学.txt', '青花瓷.txt']
63
22026.465794806718

注意:

import 语句的对应模块顺序(PEP)

  • python标准模块
  • 第三方
  • 自定义模块

自定义模块

os模块

os模块是python标准库中用于访问操作系统功能的模块。

使用os模块提供的接口,能够实现跨平台访问。

最常见的操作:

  • 目录的操作
  • 判断

1.系统操作

  • os.sep:用于查看系统路径的分隔符;

    • windows:’\‘
    • ubuntu:’/’
  • os.name:显示我们正在使用的平台

    • windows:‘nt’
    • Linux/Unix:‘posix’
  • os.getenv():读取环境变量

  • os.getcwd():获取当前路径

import os

print(os.sep)
print(os.name)
print(os.getcwd())
#输出
\
nt
D:\STUDY\周日python学习\PycharmProjects\untitled

2.目录操作----增删改查

  • os.listdir():查看路径下所有文件夹,若不给参数,则查看当前路径下所有文件夹
import os

print(os.listdir())
#输出
['.idea', '1.py', '2.py', '3.py', '3.txt', '4.py', '4.txt', '5.py', '7.py', 'dictUser1.txt', 'GreenFlowerPorcelain.txt', 'test.py', 'test.txt', 'venv', 'work-1.py', 'work-2.py', 'work-3.py', 'work-4.py', 'work-5.py', 'work-6.py', 'work-7.py', 'yh.py', '浙江大学.txt', '青花瓷.txt']
  • 目录的创建

    • os.mkdir(path):创建目录,单仅能创建一级目录
      • 若path不存在测报错
    • os.makedirs(path):创建目录,创建多级目录
  • 目录/文件删除

    • os.rmdir(path):删除目录(一级)
    • os.removedirs(path):删除空目录(多级),只能删除空目录,当目录中有文件则不处理
    • os.remove(path):删除文件,必须是文件
  • 更改路径

    • chdir():更改路径

os.chdir(’…’) #…表示上一级目录

- os.rename(old_name,new_name)

```python
os.rename('test.py','test1.py')

3.判断文件

  • os.path.exists(path):判断文件或者目录是否存在,存在返回True,不存在返回False

  • os.path.isfile(path):判断是否为文件,是,True;否,False

print(os.path.isfile('test1.py'))
#输出
True
  • os.path.isdir(path):判断是否为文件夹,是,True;否,False
print(os.path.isdir('test1.py'))
#输出
False

拓展:

  • os.path.dirname(path):返回文件路径
  • os.path.basename(path):返回文件名称
  • os.path.getsize(path):返回文件大小
  • os.path.abspath(name):返回当前文件的绝对路径
  • os.path.join(path,name):连接目录与文件名或者目录
  • os.path.split(path):将path的目录和文件名分隔开,并返回元组

4.查看文件的时间

  • os.path.getmtime(path):返回文件或者目录的最后修改时间,结果为秒数

  • os.path.getatime(path):返回文件或者目录的最后访问时间,结果为秒数

  • os.path.getctime(path):返回文件或者目录的创建时间,结果为秒数

import time,os
print(time.strftime('%Y-%m-%d %X',time.localtime(os.path.getmtime('test1.py'))))
print(time.strftime('%Y-%m-%d %X',time.localtime(os.path.getatime('test1.py'))))
print(time.strftime('%Y-%m-%d %X',time.localtime(os.path.getctime('test1.py'))))
#输出
2019-07-22 17:22:32
2019-07-22 17:22:32
2019-07-22 17:22:32

5.获取文件目录

  • os.walk(path)
import os

path=os.walk('..')
for i in path:
    print(i)
#输出
('..', ['.idea', 'Django', 'djang_test', 'untitled', 'untitled1', 'yh1'], [])
...
('..\\yh1\\__pycache__', [], ['bank.cpython-37.pyc', 'function.cpython-37.pyc', 'welcome11111.cpython-37.pyc'])

6.文件操作

常见的文件类型:

  • txt
    • 文档文件
  • csv
    • 逗号分隔值文件格式
  • json
    • 数据交换格式
  • html
    • 超文本标记语音
  • mp4
    • 声音文件

文件操作的流程:

  • 打开 —>open()
  • 读/写 —>read()/write()
  • 关闭 ---->close()
序号用途方法功能
1打开/关闭文件f=open(file)打开文件
2close()关闭文件
3读写文件内容f.read([size])从文件中读取指定的字节数;若未指定,读取所有。
4f.readline([size])读取整行,包括‘\n’
5f.readlines([size])读取所有行,并返回列表
6f.write(str)将字符串写入文件,并返回字符串长度
7f.writelines(seq)向文件写入一个序列字符串列表。如果需要换行,需要自己加入换行符
8f.flush()刷新文件缓存,直接把内部缓冲的数据写入文件
9文件的定位f.seek(offset)设置文件的当前位置,即指针位置
10f.tell()返回文件的当前位置,即指针位置

6.1 文件的打开和关闭

内置函数:open() ,创建一个file对象,之后才可以用它调用相关方法。

格式:

file_object = open(fifle,[,mode],[,encoding='utf-8'],[,buffering])

解释:

  • file_object —>open()返回的文件对象
  • file —>要打开的文件
  • mode ----->指定模式:只读,写入,追加等等。表,一般默认只读
模式描述
r以只读方式打开文件。文件的指针将会放在文件的开头。这是默认模式。
rb以二进制格式打开一个文件用于只读。文件指针将会放在文件的开头。这是默认模式。
r+打开一个文件用于读写。文件指针将会放在文件的开头。
rb+以二进制格式打开一个文件用于读写。文件指针将会放在文件的开头。
w打开一个文件只用于写入。如果该文件已存在则将其覆盖。如果该文件不存在,创建新文件。
wb以二进制格式打开一个文件只用于写入。如果该文件已存在则将其覆盖。如果该文件不存在,创建新文件。
w+打开一个文件用于读写。如果该文件已存在则将其覆盖。如果该文件不存在,创建新文件。
wb+以二进制格式打开一个文件用于读写。如果该文件已存在则将其覆盖。如果该文件不存在,创建新文件。
a打开一个文件用于追加。如果该文件已存在,文件指针将会放在文件的结尾。也就是说,新的内容将会被写入到已有内容之后。如果该文件不存在,创建新文件进行写入。
ab以二进制格式打开一个文件用于追加。如果该文件已存在,文件指针将会放在文件的结尾。也就是说,新的内容将会被写入到已有内容之后。如果该文件不存在,创建新文件进行写入。
a+打开一个文件用于读写。如果该文件已存在,文件指针将会放在文件的结尾。文件打开时会是追加模式。如果该文件不存在,创建新文件用于读写。
ab+以二进制格式打开一个文件用于追加。如果该文件已存在,文件指针将会放在文件的结尾。如果该文件不存在,创建新文件用于读写。
  • encoding ------->指定文件编码,通常使用的是’utf-8‘/‘GBK’

  • buffering ------>若设置为0,不会有寄存;若设置为1,访问文件时会寄存行,若设为大于1的数,表明寄存区的缓冲大小,若设置为负数,则寄存区的缓存区大小为系统默认。

文件对象的属性

属性描述
f.name返回文件名称
f.mode返回打开文件的访问模式
f.closed如果文件已关闭,返回true;否则,false

关闭

f.close()

节省计算机资源和提供性能,使用完文件之后,关闭它。

6.2 文件的读写

  • f.read([size])
    • 从文件指针处读取。
    • 传递size,指定读取的字节数。
  • readline()
  • readlines()
  • write()
  • wirtelines()
定位读取
  • f.tell()
    • 获取文件的当前位置
  • f.seek()
    • 格式:
      • offset,要移动的字节数
      • from,指定偏移的参考位置,如果是0,从开头偏移,如果是1,从当前位置偏移,如果是2,从末尾开始偏移。
seek(offset[,from])

random模块

导入这个模块

import random

random模块的常见功能

  • (1)random.random()
import random

a = random.random()
for i in range(100):
    a = random.random()
    print(a)

(2)random.uniform(a,b)

  • 用于生成ab之间的随机浮点数,可以取到ab,但是概率感人。
import random

a = random.random()
for i in range(100):
    a = random.uniform()
    print(a)

(3)random.randint(a,b)

  • 用于生成指定范围内的整数,[a,b]
import random

a = random.random()
for i in range(100):
    a = random.randint(6,10)
    print(a)

(4)random.randrange([start],stop,[step])

  • 从指定范围内,按指定基数递增或递减的集合中,随机获取一个整数
a = random.randrange(1,16,2)

1,3,5,7,9,11,15,

第一次1-3取。第二次1-5取,以此类推。

(5)random.choice(sequence)

  • 从序列中随机获取一个元素,sequence可以是列表,字符串,或者元组

(6)random.shuffle(x[,random])

  • 用来将一个列表的元素打乱。即将列表的元素随机排列
import random

a = random.random()
li = [1,2,3,4,5,6,7,8,9,0]
for i in range(100):
    random.shuffle(li)
    print(li)

注意返回值为null,没有返回值,直接打乱

(7)random.sample(sequence,k)

  • 用来从指定序列中随机获取指定长度的片段并随机排列,但不会修改原来的序列。
import random

a = random.random()
li = [1,2,3,4,5,6,7,8,9,0]
for i in range(100):
    a=random.sample(li,4)
    print(a)
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值