#!/usr/local/bin/python3
# -*- coding:utf-8 -*- f=open("test_1",'r',encoding="utf-8") #'r'代表读文件
'''
#----------读文件----------
print(f.tell()) #tell计数按照字符来计数
print(f.read(5)) #读前5个字符,注意此时文件指针已经到第5个
print(f.tell())
data=f.readline() #读取下一行
print(data)
print(f.tell())
f.seek(10) #文件指针指向指定的值(即第几个字符)
print(f.readline())
print(f.tell()) #----------刷新---------- #装逼方法
import sys,time
for i in range(20):
sys.stdout.write("#")
sys.stdout.flush()
time.sleep(0.1) #----------写文件----------
f1=open("test_2",'w',encoding="utf-8")#'w'代表写文件
f1.write("hello") # 注:若test_2文件已存在,那么调用f2.write()方法会将test_2文件中的内容覆盖掉
#但 若test_2文件不存在,那么write()方法会创建一个新文件 f2=open("test_2",'a',encoding="utf-8") #f2是文件句柄,'a'代表append,即追加且不覆盖原文件内容,但不可读
# 'a+'代表追加读写,即追加且不覆盖源文件内容,可读
f2.write("我爱北京天安门...\n")
f2.write("天安门上太阳升\n") #----------读取文件指定行数---------
for i in range(5): #读取文件前5行
print(f.readline()) #readline():读取文件的下一行 #----------遍历文件----------
#---low的写法---
for index,line in enumerate(f.readlines()): #f.readlines():将文件的每行作为一个元素,存入列表中
# 注:readlines()只适合读小文件,因为需要将文件作为一个列表放到
# 内存中
if index==9: #enumerate:将行标取出
print("---------------")
print(line.strip()) #去除列表元素中的空格以及换行 #---高大上的写法---
count=0
for line in f:
print(line.strip())
count+=1
if count==9:
print("---------") #----------截断----------
f3=open("test_1",'a',encoding="utf-8")#'w'代表写文件
#f2.truncate(10) #从文件的第十个字符开始截断(一个空格算一个字符),后面的内容全部消失
#---指定截断(以下方法不可行)---
f3.seek(10) #将文件指针指向第十个字符
f3.truncate(20) #期望从第十个字符开始截断,这样会保留前三十个字符
#但实际 文件指针 对truncate()方法不起作用,该方法仍旧是从头开始计数 #----------读写----------
f4=open("test_1",'r+',encoding="utf-8") #'r+'代表读写文件
print(f4.readline().strip())
print(f4.readline().strip())
print(f4.readline().strip())
print(f4.tell())
f4.write("-----------------------")
print(f4.readline().strip()) #注:虽然期望将内容写入第四行,但运行后发现插入位置随机
#但其实事实就是这样的 #----------写读1----------
f5=open("test_1",'w+',encoding="utf-8") #'w+'代表写读文件
print(f5.readline().strip())
print(f5.readline().strip())
print(f5.readline().strip())
print(f5.tell())
f5.write("-----------------------")
print(f5.readline().strip()) #注:期望将内容写入第四行,但运行后发现原文件中内容被新写入的内容
#覆盖了
#----------写读2----------
f6=open("test_1",'w+',encoding="utf-8") # 期望先写入四行,然后将文件指针退回到第十个字符上,然后打印下一行的内容
#并在此时写入最后一行,但实际运行发现:我们所期望写入的位置并没有新的内容
#新内容被写在了最后一行
f6.write("-----------1------------\n")
f6.write("-----------2------------\n")
f6.write("-----------3------------\n")
f6.write("-----------4------------\n")
print(f6.tell())
f6.seek(10)
print(f6.readline())
f6.write("----------hello---------\n")
f6.close() #----------二进制读文件----------
f7=open("test_1",'rb') #'rb'代表二进制读文件 注:此时后面encoding不能是"utf-8"
print(f7.readline()) #----------二进制写文件----------
f8=open("test_1",'wb') #'wb'代表二进制写文件 注:此时后面encoding不能是"utf-8"
f8.write("hello world\n".encode()) #注:encode ()中不指定具体的字符集,则以'utf-8'为默认
f8.close()
'''

  

python中的文件操作小结1的更多相关文章

  1. python中的文件操作小结2

    ''' #-----------文件修改---------- f=open("test_1",'r',encoding="utf-8") f2=open(&qu ...

  2. 关于Python中的文件操作(转)

    总是记不住API.昨晚写的时候用到了这些,但是没记住,于是就索性整理一下吧: python中对文件.文件夹(文件操作函数)的操作需要涉及到os模块和shutil模块. 得到当前工作目录,即当前Pyth ...

  3. python学习之【第十一篇】:Python中的文件操作

    1.前言 在Python中,对文件的操作主要遵循以下流程: 打开文件,得到文件句柄并赋值给一个变量 通过文件句柄对文件进行操作 关闭文件 2.打开文件 使用open函数,可以打开一个已经存在的文件,或 ...

  4. 【Python】解析Python中的文件操作

    目录结构: contents structure [-] 简介 Python中的文件类型 内置函数的文件操作 open()函数 Mode 创建文本文件 读取文本文件 循环文件对象 关闭文件 With语 ...

  5. 说说Python 中的文件操作 和 目录操作

    我们知道,文件名.目录名和链接名都是用一个字符串作为其标识符的,但是给我们一个标识符,我们该如何确定它所指的到底是常规文件文件名.目录名还是链接名呢?这时,我们可以使用os.path模块提供的isfi ...

  6. 2018.8.6 Python中的文件操作

    前言: 使用python来读写文件是非常简单的操作,我们使用open()函数来打开一个文件,获取到文件句柄.然后通过文件句柄就可以进行各种操作了,根据打开方式的不同能够执行的操作也会有相应的差异. 打 ...

  7. Python 中关于文件操作的注意事项

    文件操作 #打开文件 f = open('要打开的文件路径',mode = 'r/w/a', encoding = '文件原来写入时的编码') #操作 data = f.read() #读取 f.wr ...

  8. [19/10/16-星期四] Python中的文件操作

    一.打开文件 # open(file, mode='r', buffering=-1, encoding_=None, errors=None, newline=None, closefd=True, ...

  9. python中的文件操作

    文件操作时,有'r','w','a'不同的操作类型,其中'r'只能读文件,seek(),tell()函数定位读的起始地方.'w'会清空文件内容然后写文件,seek(),tell()函数定位写的起始地方 ...

随机推荐

  1. hystrix应用介绍(一)

    声明:本文仅做个人的一次接口重构过程记录,期间参考了一些写的不错的博客,如果存在抄袭,请留言. hystrix基本介绍 hystrix 是一个开源的容灾框架,目的是为了解决当依赖服务出现故障或者接口响 ...

  2. PHP+phpMyAdmin编程插入数据显示中文乱码的问题

    相信初学php的同学应该都会试一些小程序,比如从input文本框输入数据后点击提交,数据自动插入数据库保存. 但是如果是输入中文提交,不经过一定配置,在phpMyAdmin中就会显示乱码.什么%ez. ...

  3. centos6 hadoop2.7.3分布式搭建

    一.hadoop下载 apache所有的project都有自己的域名,可以通过apache官网下的project list去找,也可以直接定位project.apache.org,比如hadoop直接 ...

  4. TP5.0搭建restful API 应用

    1.配置环境变量,如果没配置会显示如下错误. 配置方法 1)右键此电脑-> 属性-> 高级系统设置->环境变量->Path 2)在Path后加上php目录的名称 如:E:\PH ...

  5. #CSS的盒子模型、元素类型

    CSS的盒子模型.元素类型   本文首先介绍了CSS元素的统一内部结构模型,盒子模型:然后介绍了CSS元素基于不同分类标准定义的元素类型,包括基于不同内容设置方式定义的replaced元素和non-r ...

  6. 显示C++数据的数据类型

    #include <typeinfo> using namespace std; ... cout << typeid(d).name() << endl; 其中, ...

  7. April 17 2017 Week 16 Monday

    You will find that it is necessary to let things go; simply for the reason that they are heavy. 你会明白 ...

  8. IA32的三种地址

    IA32的三种地址 逻辑地址:机器语言指令仍用这种地址指定一个操作数的地址或一条指令的地址. 这种寻址方式在Intel的分段结构中表现得尤为具体,它使得MS-DOS或Windows程序员把程序分为若干 ...

  9. IntelliJ IDEA / Eclipse 自动生成 Author 注释 签名

    Author 注释 签名如下: /*** @author 稚枭天卓 E-mail:zhxiaotianzhuo@163.com* @version 创建时间:2016-6-20 下午04:58:52* ...

  10. Mac安装protobuf 流程

    下载 https://github.com/google/protobuf/releases 找到对应版本下载 编译 cd protobuf./autogen.sh./configuremake 安装 ...