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

open : windows 的系统功能。

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

f.close()   关闭文件。

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

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

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

    r  只读

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

    2.文件路径: 

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

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

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

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

    2.一行一行的读。

f = open('log',encoding='utf-8')
print(f.readline())
print(f.readline())
f.close() # 顾清秋
# # 自动换行
# 顾清秋

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

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

    4.读取一部分 read(n)

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

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

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

f = open('log1',mode='rb')
content = f.read(2)
print(content)
f.close() # b'qw'

     5. 循环读取

f = open('log',encoding='utf-8')
for i in f:
print(i.strip())
f.close() # 顾清秋
# 顾清秋
# 顾清秋

   w  只写:

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

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

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

    wb  以bytes类型写入。   

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

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

     有文件,直接追加内容

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

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

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

    w+  先写后读

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

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

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

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

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

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

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

对文件进行操作的步骤:

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

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

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

   4,将原文件删除。

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

import os    #引用os模块
with open('log',encoding='utf-8') as f1,\
open('log3',encoding='utf-8',mode='w') as f2:
content = f1.read() #因为要全部读取才能替换,比较占空间,所以一般不用此方法。
new_content = content.replace('顾清秋','懒笨呆')
f2.write(new_content)
os.remove('log')
os.rename('log3','log')
import os
with open('log',encoding='utf-8') as f1,\
open('log3',encoding='utf-8',mode='w') as f2:
for i in f1:
new_i = i.replace('懒笨呆','顾清秋')
f2.write(new_i)
os.remove('log')
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. 分享知识-快乐自己:能使 Oracle 索引失效的六大限制条件

    Oracle 索引的目标是避免全表扫描,提高查询效率,但有些时候却适得其反. 例如一张表中有上百万条数据,对某个字段加了索引,但是查询时性能并没有什么提高,这可能是 oracle 索引失效造成的.or ...

  2. 利用Python检验你的策略参数是否过拟合(转)

    过拟合现象 一般来说,量化研究员在优化其交易策略参数时难免会面临这样一个问题:优化过后的策略在样本内表现一般来说均会超过其在样本外的表现,即参数过拟合.对于参数优化来说,由于优化时存在噪音,过拟合是不 ...

  3. idea结合git使用

    1.下载安装好git.exe2. 2.安装好以后在cmd输入git 3.在idea配置git环境 4.托管项目到码云 5.登录码云官网,地址就是你在码云注册的账号和密码

  4. 【spark】常用转换操作:reduceByKey和groupByKey

    1.reduceByKey(func) 功能: 使用 func 函数合并具有相同键的值. 示例: val list = List("hadoop","spark" ...

  5. 用工具快速建立hibernate框架

    ,一.建好项目后先导入两类jar包,一类是hibernate的jar包,一类是jdbc的jar包 二.点击“窗口”--“显示视图”--“其它”-“Hibernate configurations” 三 ...

  6. 内存保护机制及绕过方法——利用未启用SafeSEH模块绕过SafeSEH

    利用加载模块之外的地址绕过safeSEH 前言:文章涉及的概念在之前的文章中都有过详细的讲解 ⑴.  原理分析: 当程序加载进内存中后,处理PE文件(exe,dll),还有一些映射文件,safeSEH ...

  7. Linux下用c语言实现whereis.

    简单的一个whereis的实现,代码如下: #include <stdio.h> #include <errno.h> #include <dirent.h> #i ...

  8. LeetCode OJ:Best Time to Buy and Sell Stock II(股票买入卖出最佳实际II)

    Say you have an array for which the ith element is the price of a given stock on day i. Design an al ...

  9. react layout init

    class Layout extends React.Component { constructor(props) { super(props); } render() { return ( < ...

  10. 使用Python 2.7实现的垃圾短信识别器

    最近参加比赛,写了一个垃圾短信识别器,在这里做一下记录. 官方提供的数据是csv文件,其中训练集有80万条数据,测试集有20万条数据,训练集的格式为:行号 标记(0为普通短信,1为垃圾短信) 短信内容 ...