Python学习之文件操作

Python学习以及迷茫点整理----------------文件操作

举个例子——如何读取并统计字符个数

# 统计26个字母出现的个数
inputFile = open('XXX.txt', 'r')
char = inputFile.read(1)  # Python没有字符型,所以可以放肆一下
letterCounts = [0] * 26		# 列表+、*其实都是拼接
while char != "":
	char = char.upper()			# 字符串.upper()   将字符串中所有的小写字符转化成大写字符
	if char >= 'A' and char <= 'Z':
		code = ord(char) - ord('A')		# ord('字符名') 计算给定字符对应的ASCII码
		letterCounts[code] = letterCounts[code] + 1	  #	Python没有自增(++)和自减(--)
	char = inputFile.read(1)
inputFile.close()		# open了,就要记得close

易错点一:文件导入时的路径书写问题

报错: SyntaxError: (unicode error) ‘unicodeescape’ codec can’t decode bytes in position …
错误原因:转义错误。在python中“\”有转义的作用,如\t可代表TAB,\n代表换行,所以我们需要采取一些方式使得\不被解读为转义字符。

法一: 将‘\’全换成‘/’
inputFile = open("C:/Users/LENOVO/Desktop/Python代码/acticle.txt", 'r')

法二: 单‘\’全换成’\’
inputFile = open("C:\\Users\\LENOVO\\Desktop\\Python代码\\acticle.txt", 'r')

法三: 在路径前面加r,即保持字符原始值的意思
inputFile = open(r"C:/Users/LENOVO/Desktop/Python代码/acticle.txt", 'r')

易错点二:gbk编码问题

报错: ‘gbk’ codec can’t encode character ‘\xa0’
报错原因:在str里面存在着不能正确编码的字符。

‘’’
字符编码类型:
(常用)
1.ASCII编码 (数字、字母、特殊字符) 所有字符都只占用一个字节
2.中文GB2312(gbk) 一个汉字、一个字母都是2byte,其他并不都是
3.Unicode (每个字符占相同的字节,即定长,基本都是两个字节 ———— 加快处理速度) =====> 只用在内存中
4.UTF—8 (英文部分与ACSII一样,中文汉字占3~4个字节) ========> 程序界通用编码(Python默认)

在含有中文的内容处理中,尽量使用UTF8编码
inputFile = open('XXX.txt', 'r', encoding = 'utf-8')

Python内置的文件读写操作

更多的总结戳这里!

  • open()
格式:open('文件路径','打开模式' (,encoding = XXX))
   返回值:文件io对象(!!!)
   打开模式一共N种:
    w模式 写模式write  文件不存在时会创建文件,如果文件已存在则会清空文件
    r模式  读模式read  文件不存在就报错,存在则准备读取文件
    a模式 追加模式 append 文件不存在则新建,文件存在则在文件末尾追加内容
    x模式 抑或模式 xor 文件存在则报错,文件 不存在则新建文件
    b模式 二进制模式 binary 辅助模式不能单独使用
    +模式 增强模式plus  也是辅助模式不能单独使用
  • close() 关闭并保存文件。如果不关闭,只写进缓存,不进去文件。( open了的一定要close!!!)
  • read()
文件io对象.read() ---------> 返回值:整个文件的字符
文件io对象.read(n) --------> 返回值:指定长度的字符

#'./’——表示相对路径
f = open('./a', 'r', encoding='utf-8')
content = f.read(3)  # 读取前3个字符(此次open了后,文件指针就停在了这里)
print(content)
content = f.read()	# 读出文件中除了前面3个已经被读过的字符外的所有字符
print(content)
f.close()

- readline()

文件io对象.readline()  ------------> 返回值:一行内容的字符串
文件io对象.readline(字符长度) ------> 返回值: 某行指定长度的字符串

PS:
  字符长度 <= 当前行内容: 读取指定长度的字符串,并且在下次读取时还是读该行剩下的内容
  字符长度 >= 当前行内容:直接读取当前行
  (每次把某一行读完,系统会自动把指针移到下一行)

f = open('./a', 'r', encoding='utf-8')
content = f.readline(3) # 第一行的前3个字符
while len(content)>0:
    print(content)
    content = f.readline()  # 把第一行没读的读了,之后每次一行
f.close()

  • readlines() 读取所有的行(直到结束符EOF)并返回列表
文件io对象.readlines() ---------------> 返回值:列表
文件io对象.readlines(字符长度) --------> 返回值:读取指定行并返回成列表

f = open('./a', 'r', encoding='utf-8')
# print(f.readlines())   ---------> ['hello,python\n', 'hello java\n', 'hello php\n', 'hello c++\n']
for line in f.readlines():
    line = line.strip()		# 去掉\n
    print('读取的数据为:%s' % line)
    '''
    读取的数据为:hello,python
	读取的数据为:hello java
	读取的数据为:hello php
	读取的数据为:hello c++
    '''
f.close()

with语句 —— 会自动帮我们关闭文件,不用手动f.close()了

with open('XXX', 'r') as file:
    s = file.read()
    print(s)

file.closed    # 判断文件是否close过了
  • List item

我们对Markdown编辑器进行了一些功能拓展与语法支持,除了标准的Markdown编辑器功能,我们增加了如下几点新功能,帮助你用它写博客:

  1. 全新的界面设计 ,将会带来全新的写作体验;
  2. 在创作中心设置你喜爱的代码高亮样式,Markdown 将代码片显示选择的高亮样式 进行展示;
  3. 增加了 图片拖拽 功能,你可以将本地的图片直接拖拽到编辑区域直接展示;
  4. 全新的 KaTeX数学公式 语法;
  5. 增加了支持甘特图的mermaid语法1 功能;
  6. 增加了 多屏幕编辑 Markdown文章功能;
  7. 增加了 焦点写作模式、预览模式、简洁写作模式、左右区域同步滚轮设置 等功能,功能按钮位于编辑区域与预览区域中间;
  8. 增加了 检查列表 功能。

功能快捷键

撤销:Ctrl/Command + Z
重做:Ctrl/Command + Y
加粗:Ctrl/Command + B
斜体:Ctrl/Command + I
标题:Ctrl/Command + Shift + H
无序列表:Ctrl/Command + Shift + U
有序列表:Ctrl/Command + Shift + O
检查列表:Ctrl/Command + Shift + C
插入代码:Ctrl/Command + Shift + K
插入链接:Ctrl/Command + Shift + L
插入图片:Ctrl/Command + Shift + G
查找:Ctrl/Command + F
替换:Ctrl/Command + G

合理的创建标题,有助于目录的生成

直接输入1次#,并按下space后,将生成1级标题。
输入2次#,并按下space后,将生成2级标题。
以此类推,我们支持6级标题。有助于使用TOC语法后生成一个完美的目录。

如何改变文本的样式

强调文本 强调文本

加粗文本 加粗文本

标记文本

删除文本

引用文本

H2O is是液体。

210 运算结果是 1024.

插入链接与图片

链接: link.

图片: Alt

带尺寸的图片: Alt

居中的图片: Alt

居中并且带尺寸的图片: Alt

当然,我们为了让用户更加便捷,我们增加了图片拖拽功能。

如何插入一段漂亮的代码片

博客设置页面,选择一款你喜欢的代码片高亮样式,下面展示同样高亮的 代码片.

// An highlighted block
var foo = 'bar';

生成一个适合你的列表

  • 项目
    • 项目
      • 项目
  1. 项目1
  2. 项目2
  3. 项目3
  • 计划任务
  • 完成任务

创建一个表格

一个简单的表格是这么创建的:

项目Value
电脑$1600
手机$12
导管$1

设定内容居中、居左、居右

使用:---------:居中
使用:----------居左
使用----------:居右

第一列第二列第三列
第一列文本居中第二列文本居右第三列文本居左

SmartyPants

SmartyPants将ASCII标点字符转换为“智能”印刷标点HTML实体。例如:

TYPEASCIIHTML
Single backticks'Isn't this fun?'‘Isn’t this fun?’
Quotes"Isn't this fun?"“Isn’t this fun?”
Dashes-- is en-dash, --- is em-dash– is en-dash, — is em-dash

创建一个自定义列表

Markdown
Text-to- HTML conversion tool
Authors
John
Luke

如何创建一个注脚

一个具有注脚的文本。2

注释也是必不可少的

Markdown将文本转换为 HTML

KaTeX数学公式

您可以使用渲染LaTeX数学表达式 KaTeX:

Gamma公式展示 Γ ( n ) = ( n − 1 ) ! ∀ n ∈ N \Gamma(n) = (n-1)!\quad\forall n\in\mathbb N Γ(n)=(n1)!nN 是通过欧拉积分

Γ ( z ) = ∫ 0 ∞ t z − 1 e − t d t   . \Gamma(z) = \int_0^\infty t^{z-1}e^{-t}dt\,. Γ(z)=0tz1etdt.

你可以找到更多关于的信息 LaTeX 数学表达式here.

新的甘特图功能,丰富你的文章

2014-01-07 2014-01-09 2014-01-11 2014-01-13 2014-01-15 2014-01-17 2014-01-19 2014-01-21 已完成 进行中 计划一 计划二 现有任务 Adding GANTT diagram functionality to mermaid
  • 关于 甘特图 语法,参考 这儿,

UML 图表

可以使用UML图表进行渲染。 Mermaid. 例如下面产生的一个序列图:

张三 李四 王五 你好!李四, 最近怎么样? 你最近怎么样,王五? 我很好,谢谢! 我很好,谢谢! 李四想了很长时间, 文字太长了 不适合放在一行. 打量着王五... 很好... 王五, 你怎么样? 张三 李四 王五

这将产生一个流程图。:

链接
长方形
圆角长方形
菱形
  • 关于 Mermaid 语法,参考 这儿,

FLowchart流程图

我们依旧会支持flowchart的流程图:

Created with Raphaël 2.3.0 开始 我的操作 确认? 结束 yes no
  • 关于 Flowchart流程图 语法,参考 这儿.

导出与导入

导出

如果你想尝试使用此编辑器, 你可以在此篇文章任意编辑。当你完成了一篇文章的写作, 在上方工具栏找到 文章导出 ,生成一个.md文件或者.html文件进行本地保存。

导入

如果你想加载一篇你写过的.md文件,在上方工具栏可以选择导入功能进行对应扩展名的文件导入,
继续你的创作。


  1. mermaid语法说明 ↩︎

  2. 注脚的解释 ↩︎

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值