《笨办法学Python》 第15课手记

《笨办法学Python》 第15课手记

本节课涉及i新内容,请仔细阅读本节内容,尤其是作者的说明和常见问题解答。

原代码如下:

from sys import argv

script, filename = argv

txt = open(filename)
print "Here's your file %r:" % filename
print txt.read()

print "Type the filename again:"
file_again = raw_input("> ")

txt_again = open(file_again)

print txt_again.read()

首先,前两行代码使用argv赋值给script脚本名,赋值给filename文件名。这是在复习之前的内容。

请注意第三行,open是一个函数,功能跟它的名字相似,就是打开一个文件。open后面的括号里给出要打开的文件名。这又是一个赋值语句,将open函数得到的内容赋值给了txt。

python对open的解释如下:

python对file的解释如下:

这些英文我想你能看懂,就不提供翻译了,如果需要翻译,请在评论区留言。

也请留心print txt.read(),这里的逗号是一个运算符,表示对txt执行了read函数,括号里是函数的参数,在该处省略了参数。

这里的代码分为上下两部分,一部分以argv方式输入脚本名、文件名,另一部分使用raw_input直接输入文件名,作者意在让你比较两种方法的优劣,显然raw_input的方法更好,首先它简洁,只有一个参数,而且可以直接进行赋值操作。

运行结果如下:

至于close(),在上面的代码中加入以下代码即可,跟read的用法其实是一样的:

txt.close()
txt_agaain.close()

本节课涉及的内容:

python的open函数: Python函数:open()

1:作用:打开一个文件

2:语法([]里面的参数都是可以省略的):

open(file[, mode[, buffering[, encoding[, errors[, newline[, closefd=True]]]]]])

3:参数说明: file: 要打开的文件名,需加路径(除非是在当前目录)。唯一强制参数 mode: 文件打开的模式 buffering: 设置buffer(取值为0,1,>1) encoding: 返回数据的编码(一般为UTF8或GBK) errors: 报错级别(一般为strict,ignore) newline: 用于区分换行符(只对文本模式有效,可以取的值有None,’\n’,’\r’,”,’\r\n’) closefd: 传入的file参数类型(缺省为True)

常用的是file,mode和encoding这三个参数

4:参数详细说明: 4.1.mode:文件打开的模式。有如下几种模式 ‘r’: 以只读模式打开(缺省模式)(必须保证文件存在) ‘w’:以只写模式打开。若文件存在,则会自动清空文件,然后重新创建;若文件不存在,则新建文件。使用这个模式必须要保证文件所在目录存在,文件可以不存在。该模式下不能使用read*()方法 ‘a’:以追加模式打开。若文件存在,则会追加到文件的末尾;若文件不存在,则新建文件。该模式不能使用read*()方法。

下面四个模式要和上面的模式组合使用 ‘b’:以二进制模式打开 ‘t’: 以文本模式打开(缺省模式) ‘+’:以读写模式打开 ‘U’:以通用换行符模式打开

常见的mode组合 ‘r’或’rt’: 默认模式,文本读模式 ‘w’或’wt’: 以文本写模式打开(打开前文件会被清空) ‘rb’: 以二进制读模式打开 ‘ab’: 以二进制追加模式打开 ‘wb’: 以二进制写模式打开(打开前文件会被清空) ‘r+’: 以文本读写模式打开,可以写到文件任何位置;默认写的指针开始指在文件开头, 因此会覆写文件 ‘w+’: 以文本读写模式打开(打开前文件会被清空)。可以使用read*() ‘a+’: 以文本读写模式打开(写只能写在文件末尾)。可以使用read*() ‘rb+’: 以二进制读写模式打开 ‘wb+’: 以二进制读写模式打开(打开前文件会被清空)

‘ab+’: 以二进制读写模式打开

4.2.buffering:设置buffer 0: 代表buffer关闭(只适用于二进制模式) 1: 代表line buffer(只适用于文本模式)

1: 表示初始化的buffer大小

4.3.errors:报错级别 strict: 字符编码出现问题时会报错 ignore: 字符编码出现问题时程序会忽略而过,继续执行下面的程序

4.4.closefd: True: 传入的file参数为文件的文件名 False: 传入的file参数只能是文件描述符 Ps: 文件描述符,就是一个非负整数,在Unix内核的系统中,打开一个文件,便会返回一个文件描述符。

注意:使用open打开文件后一定要记得关闭文件对象,即使用close()。

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏FreeBuf

Flask Jinja2开发中遇到的的服务端注入问题研究

0×00. 前言 作为一个安全工程师,我们有义务去了解漏洞产生的影响,这样才能更好地帮助我们去评估风险值。本篇文章我们将继续研究Flask/Jinja2 开...

2305
来自专栏Python小屋

Python多线程编程中daemon属性的作用

在脚本运行过程中有一个主线程,若在主线程中创建了子线程,当主线程结束时根据子线程daemon属性值的不同可能会发生下面的两种情况之一: 如果某个子线程的daem...

3425
来自专栏dizhiling专栏

一行命令实现cpu占用率100%

cat /proc/cpuinfo |grep "physical id" | wc -l 可以获得CPU的个数, 我们将其表示为N.

1291
来自专栏Java工程师日常干货

【随笔】JVM核心:JVM运行和类加载

本篇博客将写一点关于JVM的东西,涉及JVM运行时数据区、类加载的过程、类加载器、ClassLoader、双亲委派机制、自定义类加载器等,这些都是博主自己的一点...

783
来自专栏Golang语言社区

Go语言Goroutine与Channel内存模型

Go语言内存模型规定了在一个goroutine中一个变量的读取的情况下,确保能够观察到在其他另外goroutine中写入同样变量的值。也就是说,如果在多个gor...

3596
来自专栏数据库

Hibernate 脏数据检查

脏数据检查: 什么是脏数据?脏数据并不是废弃和无用的数据,而是状态前后发生变化的数据。我们看下面的代码: 当事务提交时,Hibernate会对session中的...

2906
来自专栏Java学习网

Java多线程技术的9大知识点总结——精心整理

1,进程和线程的概念。 |--进程:是程序的动态执行过程,它经历了从代码加载,执行,到执行完毕的一个完整过程。 |--线程:是实现并发机制的一个有效手段。 ? ...

2676
来自专栏从零开始学自动化测试

pytest文档19-doctest测试框架

doctest从字面意思上看,那就是文档测试。doctest是python里面自带的一个模块,它实际上是单元测试的一种。 官方解释:doctest 模块会搜索那...

1612
来自专栏Golang语言社区

Go语言Goroutine与Channel内存模型

Go语言内存模型规定了在一个goroutine中一个变量的读取的情况下,确保能够观察到在其他另外goroutine中写入同样变量的值。也就是说,如果在多个gor...

36110
来自专栏前端知识分享

Vue---从后台获取数据vue-resource的使用方法

  作为前端人员,在开发过程中,我们大多数情况都需要从后台请求数据,那么在vue中怎样从后台获取数据呢?接下来,我简单介绍一下vue-resource的使用方法...

3091

扫码关注云+社区

领取腾讯云代金券