f : 变量,f_obj, file, f_handler,...文件句柄。

open : windows 的系统功能。

windows 默认编码方式:gbk。   Linux 默认编码方式:utf - 8.

f.close()   关闭文件。

  1. f = open(r'F:\顾清秋.txt',encoding='utf-8',mode='r')
  2. content = f.read()
  3. print(content)
  4. f.close()

文件执行动作(打开方式):

    只读,只写,追加,读写,写读....

    r  只读

    1.文件以什么编码方式存储的,就以什么编码方式打开,编码不一致时会报错。

    2.文件路径: 

        绝对路径:从根目录开始,一级一级查找到文件。F:\顾清秋.txt

        相对路径:从同一个文件夹下,直接写文件名即可。

    rb  非文字类文件时,用rb.  (图片,视频等...)

    1.全部都出来 f.read()

    2.一行一行的读。

  1. f = open('log',encoding='utf-8')
  2. print(f.readline())
  3. print(f.readline())
  4. f.close()
  5.  
  6. # 顾清秋
  7. # # 自动换行
  8. # 顾清秋

    3.将原文件的每一行作为一个列表的元素。

  1. f = open('log',encoding = 'utf-8')
  2. print(f.readlines())
  3. f.close()
  4.  
  5. # ['顾清秋\n', '顾清秋\n', '顾清秋']

    4.读取一部分 read(n)

    在 r 模式下,read(n)按照字符去读取。

  1. f = open('log1',encoding='utf-8')
  2. print(f.read(2))
  3. f.close()
  4.  
  5. # qw

    在 rb 模式下, read(n) 按照字节去读取。

  1. f = open('log1',mode='rb')
  2. content = f.read(2)
  3. print(content)
  4. f.close()
  5.  
  6. # b'qw'

     5. 循环读取

  1. f = open('log',encoding='utf-8')
  2. for i in f:
  3. print(i.strip())
  4. f.close()
  5.  
  6. # 顾清秋
  7. # 顾清秋
  8. # 顾清秋

   w  只写:

    没有文件,创建一个文件写入内容。

   有文件,将原文件内容清空,再写入内容。

  1. f = open('log',encoding='utf-8',mode='w')
  2. f.write('懒笨呆') #将懒笨呆写入到log文件中。
  3. f.close()

    wb  以bytes类型写入。   

  1. f = open('log',mode='wb')
  2. f.write('老男孩'.encode('utf-8')) #将‘老男孩’编码成‘utf-8'写入。
  3. f.close()

    a  没有文件,创建一个文件追加内容。

     有文件,直接追加内容

  1. f =open('log2',encoding='utf-8',mode='a')
  2. f.write('顾清秋') #将’顾清秋‘追加到'log2'文件中。
  3. f.close()

    r+  先读,后追加  一定要先读后写

  1. f = open('log1',encoding='utf-8',mode='r+') #是先读,后追加!!!!
  2. content = f.read()
  3. print(content)
  4. f.write('123q')
  5. f.close()

    w+  先写后读

  1. f = open('log',encoding='utf-8',mode='w+')
  2. f.write('zhonguo')
  3. # print(f.tell()) #按字节去读光标位置
  4. f.seek(3) #按照字节调整光标的位置
  5. print(f.read())
  6. f.close()

    truncate : 按字节对原文件截取   需要在 writing 下才可用此方法。

  1. f = open('log',encoding='utf-8',mode='a') #追加模式下
  2. f.truncate(3) #按字节对原文件截取
  3. f.close()

   with 功能一:可以不用写      close(),程序会自动close().

  1. with open('log',encoding='utf-8') as f:
  2. print(f.read())

   with 功能二:可以一次性操作多个文件句柄。

  1. with open('log',encoding='utf-8') as f1,\
  2. open('log1',encoding='utf-8') as f2: #同时对'log','log2'进行只读操作。
  3. print(f1.read())
  4. print(f2.read())

对文件进行操作的步骤:

    1,将原文件读取到内存。

   2,在内存中进行修改,形成新的内容。

   3,将新的字符串写入新文件。

   4,将原文件删除。

   5,将新文件重命名成原文件。

  1. import os #引用os模块
  2. with open('log',encoding='utf-8') as f1,\
  3. open('log3',encoding='utf-8',mode='w') as f2:
  4. content = f1.read() #因为要全部读取才能替换,比较占空间,所以一般不用此方法。
  5. new_content = content.replace('顾清秋','懒笨呆')
  6. f2.write(new_content)
  7. os.remove('log')
  8. os.rename('log3','log')
  1. import os
  2. with open('log',encoding='utf-8') as f1,\
  3. open('log3',encoding='utf-8',mode='w') as f2:
  4. for i in f1:
  5. new_i = i.replace('懒笨呆','顾清秋')
  6. f2.write(new_i)
  7. os.remove('log')
  8. os.rename('log3','log')

python's eighth day for me的更多相关文章

  1. Python从入门到精通之eighth!

    函数式编程与内置函数 函数作用域: def test1(): print('in the test1') def test(): print('in the test') return test1() ...

  2. python瓦登尔湖词频统计

    #瓦登尔湖词频统计: import string path = 'D:/python3/Walden.txt' with open(path,'r',encoding= 'utf-8') as tex ...

  3. 正则表达式匹配可以更快更简单 (but is slow in Java, Perl, PHP, Python, Ruby, ...)

    source: https://swtch.com/~rsc/regexp/regexp1.html translated by trav, travmymail@gmail.com 引言 下图是两种 ...

  4. python中关于传递参数模块argprase的一些小坑

    今天在写代码的时候遇到了一个关于parser的一些小坑,记录在此备用. 我们知道在python中可以用argprase来传递一些参数给代码执行,来看下面的例子,假设现在有一个test文件夹,下面有3个 ...

  5. Python笔记_第二篇_面向过程_第二部分_2.路径、栈和队列、内存修改

    这一部分分三个主题进行讲解,主要为后面的模块.包.第三方库的概念补充一些相关的内容. 1. 路径(Path): 相对路径和绝对路径. 举例1:我们先导入一个os库(模块)来观察一下路径 import ...

  6. 如何在Python中加速信号处理

    如何在Python中加速信号处理 This post is the eighth installment of the series of articles on the RAPIDS ecosyst ...

  7. Python中的多进程与多线程(一)

    一.背景 最近在Azkaban的测试工作中,需要在测试环境下模拟线上的调度场景进行稳定性测试.故而重操python旧业,通过python编写脚本来构造类似线上的调度场景.在脚本编写过程中,碰到这样一个 ...

  8. Python高手之路【六】python基础之字符串格式化

    Python的字符串格式化有两种方式: 百分号方式.format方式 百分号的方式相对来说比较老,而format方式则是比较先进的方式,企图替换古老的方式,目前两者并存.[PEP-3101] This ...

  9. Python 小而美的函数

    python提供了一些有趣且实用的函数,如any all zip,这些函数能够大幅简化我们得代码,可以更优雅的处理可迭代的对象,同时使用的时候也得注意一些情况   any any(iterable) ...

随机推荐

  1. lightoj1213推公式

    很容易推出来的公式ans=n^(k-1)*k*sum 然后快速幂就好了 #include<map> #include<set> #include<cmath> #i ...

  2. 在一个web 应用中,改变url无非是2种方式,一种是利用超链接进行跳转,另一种是使用浏览器的前进和回退功能

    在一个web 应用中,改变url无非是2种方式,一种是利用超链接进行跳转,另一种是使用浏览器的前进和回退功能 https://www.jianshu.com/p/27ee7df4ccc1

  3. 使用swagger作为restful api的doc文档生成——从源码中去提取restful URL接口描述文档

    初衷 记得以前写接口,写完后会整理一份API接口文档,而文档的格式如果没有具体要求的话,最终展示的文档则完全决定于开发者的心情.也许多点,也许少点.甚至,接口总是需要适应新需求的,修改了,增加了,这份 ...

  4. 【.Net】Socket小示例

    引言 项目中用到了Socket,这里做个控制台小示例记录一下. Client 客户端的Receive用了异步方法,保持长连接,可以随时发送消息和响应服务端的消息,如下 static string Cl ...

  5. LeetCode OJ:Count Primes(质数计数)

    Count the number of prime numbers less than a non-negative number, n. 计算小于n的质数的个数,当然就要用到大名鼎鼎的筛法了,代码如 ...

  6. postgresql recovery.conf文件内容说明

    在配置PG主备流复制.HA时,需要用到recovery.conf文件,这里根据自己的了解做个记录: standby_mode = 'on' #说明自己是备库 primary_conninfo = 'u ...

  7. Electron中git, npm,webpack使用

    开始学习Electron的时候用到git, 记录学习一下, 学习地址是: https://zhuanlan.zhihu.com/p/20225295?columnSlug=FrontendMagazi ...

  8. HTML中的颜色简写

    1.HTML中颜色的五种写法 1)直接用颜色英文名字表示 例如表示背景颜色为白色: 2.通过16进制数表示 例如表示背景颜色为黑色 3).通过RGB方式表示 RGB:是红色(red)绿色(green) ...

  9. Qt 出现“undefined reference to `vtable for”原因总结

    http://blog.csdn.net/chenlong12580/article/details/7431104

  10. Java并发编程之CountDownLatch

    一.场景描述 在多线程程序设计中,经常会遇到一个线程等待一个或多个线程的场景 例如:百米赛跑,十名运动员同时起跑,由于速度的快慢,肯定有先到达和后到达的,而终点有个统计成绩的仪器,当所有选手到达终点时 ...