模块与包的定义 os 模块

os模块是与操作系统交互的模块
之前我们也用过os模块就是更改文件的名字的时候

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.popen("bash command).read()  运行shell命令,获取执行结果
os.environ  获取系统环境变量

os.path
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的大小
View Code
import os
# os模块是与操作系统交互的模块、
# 之前我们就用过os模块  就是os.remove删除文件  os.rename ()给文件更改名字
# os.getcwd()  # 获取当前工作目录仅仅是python脚本工作的目录路径  类是linux获取路径 linux直接就是cwd
# os.chdir('dirname')  # 改变脚本的工作目录 相当于shell下cd  ch就是change dir
# os.curdir()  #返回当前目录  .最没用
# os.curdir()  # 返回父级是.. 也没用
# os.makedirs('dirname1/dirname2')  #可以生成多层递归目录  就是建立一个多层文件夹
# os.removedirs('dirname1/dirname2')  #若目录为空就删除 返回上一级 要是上一级也为空就再删除就依次类推一直删除
# os.mkdir('dirname') # 建立一个空的文件夹
# os.rmdir('dirname') # 删除文件夹 此文件夹必须为空
# os.listdir('dirname')  #找出你这个目录下的 所有的子目录包括隐藏的  相当于linux的tree
# os.remove() #删除一个文件
# os.rename('oldname','newname')#重命名
# os.stat('path/filename') # 获取文件/目录信息
# os.sep # 输出操作系统特定的路径分隔符
# print(os.getcwd())

模块:一个模块就是一个包含了python定义和声明的文件,文件名就是模块名字加上.py的后缀。

模块就是把一定的功能封装在一个py文件中然后可以被调用

模块存在的意义:为了方便管理,我们通常将程序分成一个个的文件,这样做程序的结构更清晰,方便管理。这时我们不仅仅可以把这些文件当做脚本去执行,还可以把他们当做模块来导入到其他的模块中,实现了功能的重复利用

导入模块使用import  导入一个模块的时候就是把这个模块从上到下的全部执行了一遍了,执行完之后再调用过来的

首次导入模块my_module时会做三件事:

  

1.为源文件(my_module模块)创建新的名称空间,在my_module中定义的函数和方法若是使用到了global时访问的就是这个名称空间。

2.在新创建的命名空间中执行模块中包含的代码,见初始导入import my_module

3.创建名字my_module来引用该命名空间

就是你先在自己的文件中开辟一个空间 这个空间用来存放你导入的模块 然后你导入模块的时候会在你本身内新创建空间中把你导入模块中的代码流程执行一遍 ,然后再去根据你的取值来调用模块中的你需要的内容

导入模块中执行的内容:

import my_moudule   #导入moudules模块
a = 10
print(my_moudule.a)  #执行导入模块中的变量a
my_moudule.trashy()  #执行你模块中函数
print(a)   #执行你本身的变量

as的使用

as 就是可以把你的导入的模块更改一个名字 一般这样可以把你难以记忆的模块的名字给更改成你容易记忆的

import my_moudule as poor  #把你的导入的模块的使用名字更改为poor
print(poor.a)  #可以直接用更改后的名字来使用导入的模块中的内容
poor.trashy()
下面就是as的典型使用场景  可以根据你的输入来判读你导入的模块
#这就是as的典型使用场景  可以根据你的输入来判读你导入的模块
inp = input('json or pickle>>>').strip()
if inp == 'json':
    import json as m
elif inp == 'pickle':
    import pickle as m

m.pickle({'k':'v'})
m.loads()
        
一次性导入多个模块:
import 模块1,模块2,模块3
也可以一次导入多个模块 但是这用一般不推荐因为这样以后你不想注销一个模块的时候不好操作

我们还可以选择导入模块中的某一个功能:

from  导入的模块   import   模块中的功能

这样导入的只能具有这个import后面中的功能不能具有导入模块中的所有功能

eg:

from my_moudule import a
print(a)
print(my_moudule.a)   #这样会报错因为你只是把模块中的a导入了进来而不是把整个模块导入进来

所以 导入的时候需要看你  import后面的内容

还有直接把模块中的内容给全部拿过来的

from  要导入的模块   import  *

这个是把所有的信息给全部都如了本地中  可以直接使用

但是一般不推荐 因为怕有一些错误的信息也带进了本文件中

from  my_moudule  import *
print(a)
print(trashy())

对于全部导入的* 有一个__all__方法最它的限制   我们可以让在2你导入的时候的__all__方法中 设置你要被导入的信息就可以限制*的内容

from  my_moudule import *
trashy()  #这个可以
trashy2()  # 这个报错 因为你导入的模块中的__all__==['a', 'trashy'] 了不包括trashy2
from ... import ...
from 模块名 import 名字
导入的名字直接属于全局,但是指向模块的名字所在的内存空间
导入的名字如果是函数或者方法,引用了全局的变量,
仍然使用模块中的变量
导入的名字和全局的名字是一样的,谁最后抢占到就是谁的
可以导入多个名字,用逗号分割
还可以起别名 as
from 模块 import * 那么默认会把模块中所有名字都导入到全局
* 和 __all__

 

猜你喜欢

转载自www.cnblogs.com/askzyl/p/8946861.html