请选择 进入手机版 | 继续访问电脑版

好程序员-千锋教育旗下高端IT职业教育品牌

400-811-9990
我的账户
好程序员

专注高端IT职业培训

亲爱的猿猿,欢迎!

已有账号,请

如尚未注册?

[Python] Python技术基础知识点:OS模块的应用

[复制链接]
沫沫老师 发表于 2018-12-14 10:12:49 | 显示全部楼层 |阅读模式 打印 上一主题 下一主题
    1.os模块
    对于文件和目录进行处理
    目录:就是文件夹
    属性:
    os.name:查看当前系统的类型,如果是windows ---> nt。如果是max ---> posix,os.environ:返回当前系统的环境变量(所有)。
    函数:
    os.environ.get():获取指定的某一个环境变量。
    路径分类:
    绝对路径:带盘符根目录的就是绝对路径。
    相对路径:相对于某个文件(参照物)所得到的一个路径值; 特点:书写的时候不带盘符的。
    os.getcwd():返回当前正在执行的.py文件所对应的完整路径(绝对路径)。
    os.listdir(path):将path路径下的所有文件和目录显示。
    os.mkdir(path):创建单层文件夹,此方法只能创建目录,如果目录已经存在,创建失败,报错。
    os.makedirs(path):创建多层文件夹(级联新建),此方法也只能创建目录,如果目录已经存在,创建失败,报错。
    os.rmdir(path):删除单层文件夹,此方法只能删除目录,如果目录不存在,删除失败,报错:FileNotFoundError。
    os.removedirs(path):删除多层文件夹(级联删除),此方法也只能删除目录,如果目录不存在,创建失败,报错。
    os.remove(path):删除文件,如果文件不存在,报错!【注意】这个方法只能删除文件不能删除目录。
    os.system():执行系统指令:cls、ipconfig、dir。
    os.path.join(path, fileName):将path和fileName中的数据拼接称为一个新的路径,以字符串的形式返回。
    os.path.isdir(path):判断path对应的路径内容是否为一个目录,如果是,返回True;反之,返回False。
    os.path.isfile(path):判断path对应的路径内容是否为一个文件,如果是,返回True;反之,返回False。
    os.path.exists(path):判断path对应的路径内容是否存在,如果存在,返回True;反之,返回False。
    os.path.getsize(path):对path对应的路径内容进行容量检测,并且返回字节量。
    os.path.basename(path):传入一个路径值,将此路径的最后一个/后面的部分返回。
    os.path.dirname(path):传入一个路径值,将此路径的最后一个/前面的部分返回。
    os.path.split(path):传入一个路径值,将此路径的最后一个/的前面部分放入到元祖的第一个元素中,/后面的部分放入到元祖的第二个元素中。
    os.path.splitext(path):传入一个路径值,将此路径的最后一个.的前面部分放入到元祖的第一个元素中,以及后面的部分放入元祖的第二个元素中。
    2.字符集(字符编码):
    ascii码:美国的标准码,范围:自己去找找看。
    unicode码:万国码,它可以包含中文,但是很可惜,它不被通用(流行)。
    utf-8码:计算机中使用最为流行,它包含了之前unicode中的内容并且扩展了,它同样可以保存中文。utf-8码保存中文字符,一个汉字占用3个字节。
    gbk码:我们中国的码表,它同样继承了gb2312,主要用于一些中文的系统,gbk保存中文字符,1个汉字占用内存2个字节。
    3.字节和字符
    记住:计算机中一切皆字节(存储方面)。
    字符:我们使用文本编辑器打开,能够看得懂的(不会乱码),就是字符文件。
    字节:我们使用文本编辑器打开,不能够看懂的,就是字节文件。
    思考:.doc结尾的文件是字符文件吗?不是。
    4.文件读取,有规定的步骤:
    1)打开文件
    2)操作数据(读、写)
    3)关闭文件 **
  打开文件:fp= open(path, 打开方式, encoding=,errors='Ignore')
       操作数据:
  打开方式:
      'r':表示只读字符(readonly)。
      #'r+':在只读的功能下,在追加一个写的功能。
      'w':表示只写字符(readwrite),第一次写完,如果没有关闭文件,继续写,那么会将原本的内容覆盖。
      #'w+':在只写的功能下,在追加一个读的功能。
      'a':表示追加内容。
      #'a+':在保留追加内容的同时,新增了一个读的功能。
      'rb':表示只读字节(二进制数据)。
      'wb':表示只写字节(二进制数据)。
  encoding:编码集如果不显示定义,对应的就是:gbk。我们也可以根据自己的需要,定义譬如:utf-8。
       errors:如果不写,默认是报错(编解码不一致),我们也可以定义为ignore,这样就不会报错了,但是会出现乱码。
    编码&解码:
    编码:程序 ---> 文件
    解码:文件 ---> 程序
    记住:如果编码和解码不一致,一定会乱码(中文情况下)
    读取文件中的数据:
    fp= open(path, ‘r’)
    content= fp.read() #读取全部内容。
    content= fp.read(num) #读取num个字节数。
    content= fp.readline() #读取一行数据。
    content= fp.readlines() #读取所有行,以一个列表的形式返回。
    print(content) #打印读取到的内容,注意,读文件,如果文件不存在,直接报错:FileNotFoundError。
    写入数据到文件中:
    fw= open(path, 'w')
    fw.write(str1) #将变量str1中的内容写入到path对应的文件中(覆盖),注意写文件,如果文件不存在,先创建文件,再写入内容;如果存在了,将以前的内容覆盖
    fw = open(path, 'a')
    fw.write(str1) #将变量str1中的内容写入到path对应的文件中(追加)
    关闭文件:fp.close() #关闭文件(释放资源)

精彩内容,一键分享给更多人!
回复

使用道具 举报

您需要登录后才可以回帖

本版积分规则

关注我们
好程序员
千锋好程序员

北京校区(总部):北京市海淀区宝盛北里西区28号中关村智诚科创大厦

深圳西部硅谷校区:深圳市宝安区宝安大道5010号深圳西部硅谷B座A区605-619

杭州龙驰智慧谷校区:浙江省杭州市下沙经济技术开发区元成路199号龙驰智慧谷B座7层

郑州校区:郑州市二七区航海中路60号海为科技园C区10层、12层

Copyright 2007-2019 北京千锋互联科技有限公司 .All Right

京ICP备12003911号-5 京公安网11010802011455号

请您保持通讯畅通1对1咨询马上开启