昨日回顾

二十八、字符编码

1.什么是字符编码

二进制和字符的映射关系

2.字符编码的发展史

unicode编码(识别所有代码)

因为unicode存储占用空间,所以用utf8来存储

utf8只和unicode对应识别

内存中unicode取,存用utf8存(硬盘),全世界的人写代码都是用utf8

3.gbk和gb2312

二十九、python2和python3的区别

python解释器启动的流程

  1. python解释器相当于文本编辑器,读入字符 --》 字符编码

    1. python2默认是ascill码读入字符;python3默认utf8读入字符
    2. 如果在pycharm中的字符用的是gbk编码写入,如果你想用python正常读入字符,必须得加上coding:gbk
  2. 解析字符(有语法和关键字的概念)--》报语法/逻辑错误
  3. 存储变量,输出(往终端打印)--》字符编码
    1. python2用两种方式存储变量

      1. u'中文'用unicode存储变量,用unicode存储变量,如果终端默认utf8格式的编码,不会乱码
      2. '中文'用coding头指定的编码存储变量,假设coding头指定编码为gbk,如果终端默认utf8格式的编码,会乱码
    2. python3默认用unicode存储变量,用unicode存储变量,如果终端默认utf8格式的编码,不会乱码

今日内容

三十、文件处理

什么是文件处理

修改存储的信息

什么是文件

操作系统提供的虚拟概念,存储信息

操作文件的流程

  1. 打开文件

    f = open(r'D:/test.py', 'w', encoding = 'utf8')
  2. 修改/读取文件

    f.write('文件内容')
    f.read()
  3. 保存文件

    f.flush()
  4. 关闭文件

    f.close()

三十一、文件的三种打开模式

  1. rt(只读)

    f = open(r'D:\上海python12期视频\python12期视频\day 09\test.py', 'rt', encoding='utf8')
    f.write('slkdjfklj')
    data = f.read()
    print(data)
    • 了解

      print(f.readline())  # 一行一行读取
      print(f.readlines())  # 读取所有行放入列表 
    • 循环读出文本内容

      for i in f.read():  # 循环出一个个字符
          print(i)
      
      for i in f:  # 循环出一行行 # 节省内存
          print(i)
      
       # 文本读一行少一行,每一行末尾默认有一个换行
  2. wt:只写(清空文件后写入,不可读)

    f = open(r'D:\上海python12期视频\python12期视频\day 09\test.py', 'wt', encoding='utf8')  # encoding指定读文件的编码格式
    f.write('abc')
    • 了解

      f.writelines(['abc', 'edf', 'gbk'])  # 自动拼接列表元素,一行写入
  3. at:只写入(追加写入)

    f = open(r'D:\上海python12期视频\python12期视频\day 09\test.py', 'at', encoding='utf8')  # encoding指定写文件的编码格式
    f.write('中')

打开文件的两种方式

  • t为文本,b为二进制模式,一般不单独使用,与r/a/w联用

  • b模式一般用于图片/音频/视频的保存
  • w和a模式可以自动创建文件

三十二、绝对路径和相对路径

  • 文件的路径

    文件在硬盘的地址

  1. 绝对路径

    从盘符开始

  2. 相对路径

    执行文件(当前运行的文件)的文件夹下的文件名,执行文件和打开文件属于同一文件夹下

未来写项目尽量使用相对路径,因为会部署到linux系统

三十三、with管理上下文

with提供一个自动关闭文件

with open('test.py','r',encoding = 'utf-8')as f:
    data = f.read()
print(data)

关闭文件但是并不会关闭python内存中的文件print(f) # 只涉及pythonprint(f.read()) # 涉及到操作系统,会报错

三十四、文件的高级应用

1.文件打开的新模式

三种新的模式(可读也可写),尽量不要使用

  1. r+ 可写可读

    with open('test.py','r+',encoding = 'utf-8') as fr:
        fr.write('haoji')  # 光标在文件头部,覆盖后面字符
  2. w+ 可写可读 (和w没有任何区别)

  3. a+ 可写可读 (默认光标在尾部)

综上:如果你真的有即可读又可写的需求,用两种不同的模式打开两次文件

2.光标的高级应用

8个进制位是1个字节,utf8中三个字节是一个中文字符,一个字节是一个英文单词

  • 这三种移动光标以字节为单位
  1. seek

    # 规定只有0、1、2三种模式,
    # 0:文件头开始
    # 1:当前光标所在位置开始
    # 2:文件末尾
    
    fr.seek(3,0)  # 开头
    fr.seek(3,1)  # 当前光标
    fr.seek(3,2)  # 末尾
  2. tell:得出当前位置

    with open('test.py', 'rb') as fr:
        fr.seek(3, 0)
        print(fr.tell())
  3. truncate:截断

    with open('test.py', 'ab') as fa:
        fa.truncate(2)
  • 以字符为单位移动光标

    read

    with open('test.py', 'r', encoding='utf8') as fr:
            print(fr.read(3))  # n表示n个字符,不加默认读取所有 # 中文和英文都属于一个字符

登陆注册

# 注册
count = 0
while count < 3:
    username_inp = input('请输入你的用户名:')
    pwd_inp = input('请输入你的密码:')
    re_pwd_inp = input('请在此输入你的密码:')

    if not pwd_inp == re_pwd_inp:
        print('两次密码输入不一致')
        count += 1
        continue

    with open('user_info.txt', 'a', encoding='utf8') as fa:
        fa.write(f'{username_inp}:{pwd_inp}\n')  # :表示用户名和密码的分割;|用户和用户之间的分割
        fa.flush()
        break
# 登录
username_inp = input('请输入你的用户名:')
pwd_inp = input('请输入你的密码:')

with open('user_info.txt', 'r', encoding='utf8') as fr:
    for user_info in fr:
        username, pwd = user_info.split(':')

        if username.strip() == username_inp and pwd.strip() == pwd_inp:  # strip可以去掉两端的换行符
            print('登录成功')
            break
        # else:
        #     continue  # continue一般不写在最后一行
    else:
        print('登录失败')

文件的修改

#文件没有修改一说,只有覆盖
#缓存文件的原理
with open('test.py', 'r', encoding='utf8') as fr, \
        open('test_swap.py', 'w', encoding='utf8') as fw:
    data = fr.read()
    data = data.replace('sb', '傻逼')

    fw.write(data)

import os

os.remove('test.py')
os.rename('test_swap.py', 'test.py')

with open('test.py', 'r', encoding='utf8') as fr, \
        open('test_swap.py', 'w', encoding='utf8') as fw:
    # 再大的文件都能修改
    for i in fr:
        s = '傻逼'
        i = i.replace('sb', s)
        fw.write(i)
        # fw.flush()  # 先保存成功再继续运行

import os

os.remove('test.py')
os.rename('test_swap.py', 'test.py')

import os

print(os.listdir(r'D:\上海python12期视频\python12期视频'))

最新文章

  1. 用 ROS 做内网DNS服务器
  2. ANT 环境搭建
  3. Servlet&amp;jsp基础:第五部分
  4. sql server远程访问Oracle数据库
  5. MVC Dynamic Authorization--示例市在Action前进行的验证,应提前到Auth过滤器
  6. 找出程序cpu使用率高的原因
  7. Python Learing(二):Basic Image Processing 1
  8. STM32驱动AT24CXX系列芯片
  9. XAMPP的配置与使用
  10. WPF 自定义滚动条(ScrollView、ScrollBar)样式
  11. MongoDB【快速入门】
  12. linux 路由表 的一些相关资料
  13. 【python】Numpy中stack(),hstack(),vstack()函数详解
  14. ATM取款机数据库设计
  15. jquery实现星级评分
  16. OpenGL资料
  17. [算法]用java实现堆操作
  18. 004 Hadoop2.x基础知识
  19. 面向对象 ( OO ) 的程序设计——理解对象
  20. 数据结构实习 - Problem N 树的括号表示法

热门文章

  1. Spark开发常用参数
  2. filebeat使用multiline丢失数据问题
  3. kvm-web管理工具webvirtmgr
  4. java架构之路-(分布式)初识zookeeper安装与参数详解
  5. ajax跨域问题以及解决方案
  6. j2ee开发之struts2框架学习笔记
  7. MongoDB的基本操作(增删改查)
  8. ServiceStack.Redis高效封装和简易破解
  9. 快学Scala 第一课 (变量,类型,操作符)
  10. Vue学习系列(一)——初识Vue.js核心