'''
'如何打开一个文件
模特主妇护士老师.txt
1. 文件路径:f:\模特主妇护士老师.txt
2. 操作方式:只读:r ,rb ,只写: w, wb ,追加: a , ab,读写:r+ , r+b,写读 :w+ , w+b ......
3. 编码方式

以什么编码方式储存的文件,就以什么编码打开进行操作

'''

绝对路径: 从根目录开始
f = open('f:\模特主妇护士老师.txt', mode = 'r', encoding = 'utf-8')
content = f.read()
print(content)
f.close()

相对路径: 从当前目录开始

只读 r

bytes --> str
f = open('模特主妇护士老师.txt', mode = 'r', encoding = 'utf-8')
content = f.read()
print(content,type(content))
f.close()

f = open('模特主妇护士老师.txt', mode = 'rb')
content = f.read()
print(content)
f.close()

对于写 w ,没有此文件就会创建文件

f = open('log', mode = 'w', encoding = 'utf-8')
f.write('骑兵步兵')
f.close()

先将源文件的内容全部清除,再进行写操作

f = open('log', mode = 'w', encoding = 'utf-8')
f.write('回房间ask东方航空')
f.close()

f = open('log', mode = 'wb')
f.write('回房间ask东方航空'.encode('utf-8'))
f.close()

追加

f = open('log', mode = 'wb')
f.write('回房间ask东方航空'.encode('utf-8'))
f.close()

追加

f = open('log',mode = 'a', encoding = 'utf-8')
f.write('kidd')
f.close()

f = open('log',mode = 'a+', encoding = 'utf-8')
f.write('kidd')
f.seek(0) # + 可以用seek(),寻找光标
print(f.read())
f.close()

f = open('log',mode = 'ab')
f.write('KID'.encode('utf-8'))
f.close()

读写

f = open('log', mode = 'r+', encoding = 'utf-8')
print(f.read())
f.write('尹宁')
print(f.read())
f.close()

写读

r+ 模式下 进行写读,从头开始写

f = open('log', mode = 'r+', encoding = 'utf-8')
f.write('KID')
print(f.read())
f.close()

f = open('log', mode = 'r+', encoding = 'utf-8')
f.write('KIDDDDDDDD')
print(f.read())
f.close()

读写

# 后面加 b , 就不写encoding = ''了

f = open('log', mode = 'r+b')
print(f.read())
f.write('尹宁'.encode('utf-8'))
f.close()

写读 w+

f = open('log', mode = 'w+', encoding = 'utf-8')
f.write('KID')
f.seek(0)
print(f.read())
f.close()

功能详解
最常用的就是r+

read()、seek()、

f = open('log', mode = 'r+', encoding = 'utf-8')
# content = f.read(3) # 读出前三个字符(读出来的都是字符)
f.seek(3) #移动光标是按照字节定光标的位置,一个中文是三个字节,故只能是3 的倍数
print(f.tell()) # 告诉你光标的位置
# content = f.read()
# print(content)
f.close()

f = open('log',mode = 'a+', encoding = 'utf-8')
f.write('kidd')
content = f.tell()
f.seek(content - 3) # 中文是一个字符(三个字节),英文是三个字符(三个字节)
print(f.read())
f.close()

f = open('log', mode = 'r+', encoding = 'utf-8')
f.tell()
f.readable() #是否可读
line = f.readline() # 一行一行的读
line = f.readlines() # 每一行当成列表中的一个元素,添加到list中(for循环)
f.truncate(4)
print(l1)
for line in f:
print(line)
f.close()

with open('log', mode = 'r+', encoding = 'utf-8') as obj:
print(obj.read()) # close() 不用写,自动关闭

with open('log', mode = 'r+', encoding = 'utf-8') as f1,open('log', mode = 'r+', encoding = 'utf-8') as f2:
print(f1.read()) # 可以打开多个
print(f2.read())

python学习之老男孩python全栈第九期_day008知识点总结的更多相关文章

  1. python学习之老男孩python全栈第九期_day027知识点总结——反射、类的内置方法

    一. 反射 ''' # isinstance class A:pass class B(A):pass a = A() print(isinstance(a,A)) # 判断对象和类的关系 print ...

  2. python学习之老男孩python全栈第九期_day023知识点总结——类和对象命名空间、组合

    一. 类和对象命名空间类里 可以定义两种属性: 1. 静态属性 2. 动态属性 class Course: language = 'Chinese' def __init__(self, teache ...

  3. python学习之老男孩python全栈第九期_day019知识点总结——collections模块、时间模块、random模块、os模块、sys模块

    一. collections模块 在内置数据类型(dict.list.set.tuple)的基础上,collections模块还提供了几个额外的数据类型:namedtuple.deque.Counte ...

  4. python学习之老男孩python全栈第九期_day017知识点总结——初识递归、算法

    一. 递归函数 如果一个函数在内部调用自身本身,这个函数就是递归函数. 最大递归深度默认是997 -- python从内存角度出发做得限制(而不是程序真的报错),最大深度可以修改 def func(n ...

  5. python学习之老男孩python全栈第九期_day010知识点总结

    def qqxing(l = []): # 可变数据类型 l.append(1) print(l)qqxing() # [1]qqxing([]) # [1]qqxing() # [1, 1]qqxi ...

  6. python学习之老男孩python全栈第九期_day007知识点总结

    基础数据类型汇总 1. str 2. int 3. list 4. bool 5. dict (1) fromkeys Python 字典 fromkeys() 方法用于创建一个新的字典,并以可迭代对 ...

  7. python学习之老男孩python全栈第九期_day001知识点总结

    1. Python2与Python3的区别: Python2:源码不标准,混乱,重复代码太多: Python3:统一标准,去除重复代码. 编码方式: python2的默认编码方式为ASCII码:pyt ...

  8. python学习之老男孩python全栈第九期_day014知识点总结

    # 迭代器和生成器# 迭代器 # 双下方法:很少直接调用的方法,一般情况下,是通过其他语法触发的# 可迭代的 --> 可迭代协议:含有__iter__的方法( '__iter__' in dir ...

  9. python学习之老男孩python全栈第九期_day016知识点总结

    '''数据类型:intbool... 数据结构:dict (python独有的)listtuple (pytho独有的)setstr''' # reverse() 反转l = [1,2,3,4,5]l ...

随机推荐

  1. ASP.NET Core WebApi 项目部署到 IIS 服务器的总结

    Point: - ASP.NET Core WebApi 项目 - 发布到 IIS 服务器 1. 选择 File System 2. 输入要发布到的路径 # 其它默认,直接发布 3. 打开 IIS,添 ...

  2. 《deep sort》复现过程

    目录 1. 准备代码与数据 deep_sort开源代码 克隆到本地服务器 git clone https://github.com/nwojke/deep_sort.git 下载MOT16数据集(MO ...

  3. web3调用call()方法获取不到返回值

    一.web3的call()获取不到返回值问题和解决方法 在彩票小合约中,遇到一个问题:合约中 有两个方法 第一个返回一个账户地址,没有使用到当前方法调用者信息: 第二个使用到了当前方法调用者信息 在w ...

  4. (转)IBM AppScan 安全漏洞问题修复(.net)

    原文:https://www.cnblogs.com/anngeiBKY/p/4952269.html 按问题类型分类的问题 使用 SQL 注入的认证旁路2 已解密的登录请求3 登录错误消息凭证枚举1 ...

  5. (转)request模拟知乎登录(无验证码机制

    原文:http://www.itnose.net/detail/6755805.html import request try: import cookielib #python2版本 except: ...

  6. CDN基本工作过程

    看了一些介绍CDN的文章,感觉这篇是讲的最清楚的. 使用CDN会极大地简化网站的系统维护工作量,网站维护人员只需将网站内容注入CDN的系统,通过CDN部署在各个物理位置的服务器进行全网分发,就可以实现 ...

  7. tensorflow 优化图

    当我们把训练好的tensorflow训练图拿来进行预测时,会有多个训练时生成的节点,这些节点是不必要的,我们需要在预测的时候进行删除. 下面以bert的图为例,进行优化 def optimize_gr ...

  8. es-06-java创建mapping和setting

    说实话, java的方式太繁琐, 不如直接使用DSL进行创建 1, create package com.wenbronk.elasticsearch.usage.index; import com. ...

  9. SSM整合(2): spring 与 mybatis 整合

    在进行完spring与springmvc整合之后, 继续 spring与mybatis的整合. 既然是操作数据库, 那必然不能缺少了连接属性 一. db.properties jdbc.driver= ...

  10. SOA,Webservice,SOAP,REST,RPC,RMI的区别与联系

    SOA,Webservice,SOAP,REST,RPC,RMI的区别与联系 SOA面向服务的软件架构(Service Oriented Architecture) 是一种计算机软件的设计模式,主要应 ...