python(7)-- 文件I/O
1 打印到屏幕:print 语句。你可以给它传递零个或多个用逗号隔开的表达式。此函数把你传递的表达式转换成一个字符串表达式,并将结果写到标准输出,eg:print "Python 是一个非常棒的语言,不是吗?"; ---- 结果输出:Python 是一个非常棒的语言,不是吗?
2 读取键盘输入:Python提供了两个内置函数从 标准输入(默认的标准输入是键盘)读入 一行文本。如下:
- raw_input([prompt]) 函数: 从标准输入读取一个行,并返回一个字符串(去掉结尾的换行符),eg:
#!/usr/bin/python # -*- coding: UTF- -*- str = raw_input("请输入:"); print "你输入的内容是: ", str '''这将提示你输入任意字符串,然后在屏幕上显示相同的字符串。当我输入"Hello Python!",它的输出如下:''' 请输入:Hello Python! 你输入的内容是: Hello Python! - input([prompt]) 函数: 和 raw_input([prompt]) 函数基本类似,但是 input 可以接收一个Python表达式作为输入,并将运算结果返回。eg:
#!/usr/bin/python # -*- coding: UTF- -*- str = input("请输入:"); print "你输入的内容是: ", str ''' 说明:[x*5 for x in range(2,10,2)] 是python中的生成器,生成一个列表。--- 你从表达式可以看出是生成5*x,x是2-10范围内,以2为步长的元素。那就是2 4 6 8,所以生成了[10, 20, 30, 40]。这会产生如下的对应着输入的结果:''' 请输入:[x* ,,)] 你输入的内容是: [, , , ]
3 打开 or 关闭文件:Python 提供了必要的函数和方法进行默认情况下的文件基本操作。你可以用 file 对象做大部分的文件操作。
(1) 打开文件:(open 函数):你必须先用Python内置的open()函数打开一个文件,创建一个file对象,相关的方法才可以调用它进行读写。语法:
file object = open(file_name [, access_mode][, buffering])
--- 各个参数的细节如下:
- file_name:file_name变量是一个包含了你要访问的文件名称的字符串值。
- access_mode:access_mode决定了打开文件的模式:只读,写入,追加等。所有可取值见如下的完全列表。这个参数是非强制的,默认文件访问模式为只读(r)。
- buffering (缓冲区): 如果buffering的值被设为0,就不会有寄存。如果buffering的值取1,访问文件时会寄存行。如果将buffering的值设为大于1的整数,表明了这就是的寄存区的缓冲大小。如果取负值,寄存区的缓冲大小则为系统默认。
--- 不同模式打开文件的完全列表:

--- File对象的属性:一个文件被打开后,你有一个file对象,你可以得到有关该文件的各种信息。以下是和file对象相关的所有属性的列表:

示例:
#!/usr/bin/python
# -*- coding: UTF- -*-
# 打开一个文件
fo = open("foo.txt", "wb")
print "文件名: ", fo.name
print "是否已关闭 : ", fo.closed
print "访问模式 : ", fo.mode
print "末尾是否强制加空格 : ", fo.softspace
以上实例输出结果:
文件名: foo.txt
是否已关闭 : False
访问模式 : wb
末尾是否强制加空格 :
(2)关闭文件(close函数):File 对象的 close()方法刷新缓冲区里任何还没写入的信息,并关闭该文件,这之后便不能再进行写入。
当一个文件对象的引用被重新指定给另一个文件时,Python 会关闭之前的文件。用 close()方法关闭文件是一个很好的习惯。语法:
fileObject.close();
示例:
例子:
#!/usr/bin/python
# -*- coding: UTF- -*-
# 打开一个文件
fo = open("foo.txt", "wb")
print "文件名: ", fo.name
# 关闭打开的文件
fo.close()
以上实例输出结果:
文件名: foo.txt
4 读写文件:file对象提供了一系列方法,能让我们的文件访问更轻松。来看看如何使用read()和write()方法来读取和写入文件。
- write() 方法:write()方法可将任何字符串写入一个打开的文件。
注意:(a) Python字符串可以是二进制数据,而不是仅仅是文字;
(b) write()方法不会在字符串的结尾添加换行符('\n').
语法:
fileObject.write(string); # 在这里,被传递的参数是要写入到已打开文件的内容。
eg:
#!/usr/bin/python # -*- coding: UTF-8 -*- # 打开一个文件 fo = open("foo.txt", "wb") fo.write( "www.runoob.com!\nVery good site!\n"); # 关闭打开的文件 fo.close()''' 上述方法会创建foo.txt文件,并将收到的内容写入该文件,并最终关闭文件。如果你打开这个文件,将看到以下内容: '''
$ cat foo.txt # 该句指 打开该文件 foo.txt www.runoob.com! Very good site!
- read() 方法: read()方法从一个打开的文件中读取一个字符串。需要重点注意的是,Python字符串可以是二进制数据,而不是仅仅是文字。
语法:fileObject.read([count]); # 在这里,被传递的参数是要从已打开文件中读取的字节计数。该方法从文件的开头开始读入,如果没有传入count,它会尝试尽可能多地读取更多的内容,很可能是直到文件的末尾。
eg: 这里我们用到以上创建的 foo.txt 文件。
#!/usr/bin/python # -*- coding: UTF-8 -*- # 打开一个文件 fo = open("foo.txt", "r+") str = fo.read(10); print "读取的字符串是 : ", str # 关闭打开的文件 fo.close()以上实例输出结果:
读取的字符串是 : www.runoob
5 文件位置(定位):
- tell()方法: 告诉你文件内的当前位置;换句话说,下一次的读写会发生在文件开头这么多字节之后。
- seak(offset [,from])方法: 改变当前文件的位置。Offset变量表示要移动的字节数。From变量指定开始移动字节的参考位置。--- 如果from被设为0,这意味着将文件的开头作为移动字节的参考位置。如果设为1,则使用当前的位置作为参考位置。如果它被设为2,那么该文件的末尾将作为参考位置。
示例:就用我们上面创建的文件foo.txt。
#!/usr/bin/python
# -*- coding: UTF- -*-
# 打开一个文件
fo = open("foo.txt", "r+")
str = fo.read();
print "读取的字符串是 : ", str
# 查找当前位置
position = fo.tell();
print "当前文件位置 : ", position
# 把指针再次重新定位到文件开头
position = fo.seek(, );
str = fo.read();
print "重新读取字符串 : ", str
# 关闭打开的文件
fo.close()
以上实例输出结果:
读取的字符串是 : www.runoob
当前文件位置 :
重新读取字符串 : www.runoob
6 重命名 和 删除文件:Python的os模块提供了帮你执行文件处理操作的方法,比如重命名和删除文件。要使用这个模块,你必须先导入它,然后才可以调用相关的各种功能。
- rename()方法: rename()方法需要两个参数,当前的文件名和新文件名。语法:
os.rename(current_file_name, new_file_name)
示例:下例将重命名一个已经存在的文件test1.txt。
#!/usr/bin/python # -*- coding: UTF- -*- import os # 重命名文件test1.txt到test2.txt。 os.rename( "test1.txt", "test2.txt" )
- remove()方法: 你可以用remove()方法删除文件,需要提供要删除的文件名作为参数。语法:
os.remove(file_name)
示例:下例将删除一个已经存在的文件test2.txt。
#!/usr/bin/python # -*- coding: UTF- -*- import os # 删除一个已经存在的文件test2.txt os.remove("test2.txt")
7 python 里的目录:所有文件都包含在各个不同的目录下,不过Python也能轻松处理。os模块有许多方法能帮你创建,删除和更改目录。
- mkdir()方法: 可以使用os模块的mkdir()方法在当前目录下创建新的目录们。你需要提供一个包含了要创建的目录名称的参数。语法:
os.mkdir("newdir")示例:下例将在当前目录下创建一个新目录test。
#!/usr/bin/python # -*- coding: UTF- -*- import os # 创建目录test os.mkdir("test") - chdir()方法: 可以用chdir()方法来改变当前的目录。chdir()方法需要的一个参数是你想设成当前目录的目录名称。语法:
os.chdir("newdir")示例:下面将进入"/home/newdir"目录。
#!/usr/bin/python # -*- coding: UTF- -*- import os # 将当前目录改为"/home/newdir" os.chdir("/home/newdir")
- getcwd()方法: getcwd()方法显示当前的工作目录。语法:
os.getcwd()
示例:下例给出当前目录:
#!/usr/bin/python # -*- coding: UTF- -*- import os # 给出当前的目录 print os.getcwd()
- rmdir()方法: rmdir()方法删除目录,目录名称以参数传递。在删除这个目录之前,它的所有内容应该先被清除。语法:
os.rmdir('dirname')示例:以下是删除" /tmp/test"目录的例子。目录的完全合规的名称必须被给出,否则会在当前目录下搜索该目录。
#!/usr/bin/python # -*- coding: UTF- -*- import os # 删除”/tmp/test”目录 os.rmdir( "/tmp/test" )
文件、目录相关的方法:三个重要的方法来源能对Windows和Unix操作系统上的文件及目录进行一个广泛且实用的处理及操控,如下:
- File 对象方法: file对象提供了操作文件的一系列方法。
file.close():关闭文件。关闭后文件不能再进行读写操作。 file.flush():刷新文件内部缓冲,直接把内部缓冲区的数据立刻写入文件, 而不是被动的等待输出缓冲区写入。 file.fileno():返回一个整型的文件描述符(file descriptor FD 整型), 可以用在如os模块的read方法等一些底层操作上。 file.isatty():如果文件连接到一个终端设备返回 True,否则返回 False。 file.next():返回文件下一行。 file.read([size]):从文件读取指定的字节数,如果未给定或为负则读取所有。 file.readline([size]):读取整行,包括 "\n" 字符。 file.readlines([sizehint]):读取所有行并返回列表,若给定sizeint>,返回总和大约为sizeint字节的行, 实际读取值可能比sizhint较大, 因为需要填充缓冲区。 file.seek(offset[, whence]):设置文件当前位置 file.tell():返回文件当前位置。 file.truncate([size]):截取文件,截取的字节通过size指定,默认为当前文件位置。 file.write(str):将字符串写入文件,没有返回值。 file.writelines(sequence):向文件写入一个序列字符串列表,如果需要换行则要自己加入每行的换行符。
- OS 对象方法: 提供了处理文件及目录的一系列方法。
os.access(path, mode):检验权限模式 os.chdir(path):改变当前工作目录 os.chflags(path, flags):设置路径的标记为数字标记。 os.chmod(path, mode):更改权限 os.chown(path, uid, gid):更改文件所有者 os.chroot(path):改变当前进程的根目录 os.close(fd):关闭文件描述符 fd os.closerange(fd_low, fd_high):关闭所有文件描述符,从 fd_low (包含) 到 fd_high (不包含), 错误会忽略 os.dup(fd):复制文件描述符 fd os.dup2(fd, fd2):将一个文件描述符 fd 复制到另一个 fd2 os.fchdir(fd):通过文件描述符改变当前工作目录 os.fchmod(fd, mode):改变一个文件的访问权限,该文件由参数fd指定,参数mode是Unix下的文件访问权限。 os.fchown(fd, uid, gid):修改一个文件的所有权,这个函数修改一个文件的用户ID和用户组ID,该文件由文件描述符fd指定。 os.fdatasync(fd):强制将文件写入磁盘,该文件由文件描述符fd指定,但是不强制更新文件的状态信息。 os.fdopen(fd[, mode[, bufsize]]):通过文件描述符 fd 创建一个文件对象,并返回这个文件对象 os.fpathconf(fd, name):返回一个打开的文件的系统配置信息。name为检索的系统配置的值,它也许是一个定义系统值的字符串,这些名字在很多标准中指定(POSIX., Unix , Unix , 和其它)。 os.fstat(fd):返回文件描述符fd的状态,像stat()。 os.fstatvfs(fd):返回包含文件描述符fd的文件的文件系统的信息,像 statvfs() os.fsync(fd):强制将文件描述符为fd的文件写入硬盘。 os.ftruncate(fd, length):裁剪文件描述符fd对应的文件, 所以它最大不能超过文件大小。 os.getcwd():返回当前工作目录 os.getcwdu():返回一个当前工作目录的Unicode对象 os.isatty(fd):如果文件描述符fd是打开的,同时与tty(-like)设备相连,则返回true, 否则False。 os.lchflags(path, flags):设置路径的标记为数字标记,类似 chflags(),但是没有软链接 os.lchmod(path, mode):修改连接文件权限 os.lchown(path, uid, gid):更改文件所有者,类似 chown,但是不追踪链接。 os.link(src, dst):创建硬链接,名为参数 dst,指向参数 src os.listdir(path):返回path指定的文件夹包含的文件或文件夹的名字的列表。 os.lseek(fd, pos, how):设置文件描述符 fd当前位置为pos, how方式修改: SEEK_SET 或者 设置从文件开始的计算的pos; SEEK_CUR或者 则从当前位置计算; os.SEEK_END或者2则从文件尾部开始. 在unix,Windows中有效 os.lstat(path):像stat(),但是没有软链接 os.major(device):从原始的设备号中提取设备major号码 (使用stat中的st_dev或者st_rdev field)。 os.makedev(major, minor):以major和minor设备号组成一个原始设备号 os.makedirs(path[, mode]):递归文件夹创建函数。像mkdir(), 但创建的所有intermediate-level文件夹需要包含子文件夹。 os.minor(device):从原始的设备号中提取设备minor号码 (使用stat中的st_dev或者st_rdev field )。 os.mkdir(path[, mode]):以数字mode的mode创建一个名为path的文件夹.默认的 mode 是 (八进制)。 os.mkfifo(path[, mode]):创建命名管道,mode 为数字,默认为 (八进制) os.mknod(filename[, mode=, device]):创建一个名为filename文件系统节点(文件,设备特别文件或者命名pipe)。 os.open(file, flags[, mode]):打开一个文件,并且设置需要的打开选项,mode参数是可选的 os.openpty():打开一个新的伪终端对。返回 pty 和 tty的文件描述符。 os.pathconf(path, name):返回相关文件的系统配置信息。 os.pipe():创建一个管道. 返回一对文件描述符(r, w) 分别为读和写 os.popen(command[, mode[, bufsize]]):从一个 command 打开一个管道 os.read(fd, n):从文件描述符 fd 中读取最多 n 个字节,返回包含读取字节的字符串,文件描述符 fd对应文件已达到结尾, 返回一个空字符串。 os.readlink(path):返回软链接所指向的文件 os.remove(path):删除路径为path的文件。如果path 是一个文件夹,将抛出OSError; 查看下面的rmdir()删除一个 directory。 os.removedirs(path):递归删除目录。 os.rename(src, dst):重命名文件或目录,从 src 到 dst os.renames(old, new):递归地对目录进行更名,也可以对文件进行更名。 os.rmdir(path):删除path指定的空目录,如果目录非空,则抛出一个OSError异常。 os.stat(path):获取path指定的路径的信息,功能等同于C API中的stat()系统调用。 os.stat_float_times([newvalue]):决定stat_result是否以float对象显示时间戳 os.statvfs(path):获取指定路径的文件系统统计信息 os.symlink(src, dst):创建一个软链接 os.tcgetpgrp(fd):返回与终端fd(一个由os.open()返回的打开的文件描述符)关联的进程组 os.tcsetpgrp(fd, pg):设置与终端fd(一个由os.open()返回的打开的文件描述符)关联的进程组为pg。 os.tempnam([dir[, prefix]]):返回唯一的路径名用于创建临时文件。 os.tmpfile():返回一个打开的模式为(w+b)的文件对象 .这文件对象没有文件夹入口,没有文件描述符,将会自动删除。 os.tmpnam():为创建一个临时文件返回一个唯一的路径 os.ttyname(fd):返回一个字符串,它表示与文件描述符fd 关联的终端设备。如果fd 没有与终端设备关联,则引发一个异常。 os.unlink(path):删除文件路径 os.utime(path, times):返回指定的path文件的访问和修改的时间。 os.walk(top[, topdown=True[, onerror=None[, followlinks=False]]]):输出在文件夹中的文件名通过在树中游走,向上或者向下。 os.write(fd, str): 写入字符串到文件描述符 fd中. 返回实际写入的字符串长度
python(7)-- 文件I/O的更多相关文章
- Python读写文件
Python读写文件1.open使用open打开文件后一定要记得调用文件对象的close()方法.比如可以用try/finally语句来确保最后能关闭文件. file_object = open('t ...
- python计算文件的md5值
前言 最近要开发一个基于python的合并文件夹/目录的程序,本来的想法是基于修改时间的比较,即判断文件有没有改变,比较两个文件的修改时间即可.这个想法在windows的pc端下测试没有问题. 但是当 ...
- python操作文件案例二则
前言 python 对于文件及文件夹的操作. 涉及到 遍历文件夹下所有文件 ,文件的读写和操作 等等. 代码一 作用:查找文件夹下(包括子文件夹)下所有文件的名字,找出 名字中含有中文或者空格的文件 ...
- Python :open文件操作,配合read()使用!
python:open/文件操作 open/文件操作f=open('/tmp/hello','w') #open(路径+文件名,读写模式) 如何打开文件 handle=open(file_name,a ...
- python学习 文件操作
一.python打开文件 #=====================python 文件打开方式 open()===================== # open(fileName,type) t ...
- Python之文件读写
本节内容: I/O操作概述 文件读写实现原理与操作步骤 文件打开模式 Python文件操作步骤示例 Python文件读取相关方法 文件读写与字符编码 一.I/O操作概述 I/O在计算机中是指Input ...
- python 遍历文件夹 文件
python 遍历文件夹 文件 import os import os.path rootdir = "d:\data" # 指明被遍历的文件夹 for parent,dirn ...
- python检测文件的MD5值
python检测文件的MD5值MD5(单向散列算法)的全称是Message-Digest Algorithm 5(信息-摘要算法),经MD2.MD3和MD4发展而来.MD5算法的使用不需要支付任何版权 ...
- Python编码/文件读取/多线程
Python编码/文件读取/多线程 个人笔记~~记录才有成长 编码/文件读取/多线程 编码 常用的一般是gbk.utf-8,而在python中字符串一般是用Unicode来操作,这样才能按照单个字 ...
- python 读写文件和设置文件的字符编码
一. python打开文件代码如下: f = open("d:\test.txt", "w") 说明:第一个参数是文件名称,包括路径:第二个参数是打开的模式mo ...
随机推荐
- AFN post的数据编码格式问题
想到写任何关于AFN的东西其实我是拒绝的,因为自己这也是第一次用,毕竟AFN现在是最为流行的网络框架了,害怕自己理解的有误,所以不敢造次! 先在这里大致讲解一下过程吧,后期发现了再更正(主要是想让看官 ...
- Android驱动开发5-7总结
Android深度探索5-7章总结 介绍了S3C6410开发板的功能,开发板的不同主要是在烧录嵌入式系统的方式不同,以及如何在此开发板上安装Android.紧接着学到介绍到如何在多种平台,使用多种方式 ...
- 【搜索】【入门】洛谷P1036 选数
题目描述 已知 n个整数x1,x2,…,xn,以及1个整数k(k<n).从nn个整数中任选kk个整数相加,可分别得到一系列的和. 例如当n=4,k=3,4个整数分别为3,7,12,19时, ...
- mysql查询哪个表数据量最大
use information_schema;select table_name,table_rows from tables where table_schema='cargo_new' order ...
- 5-1 json模块
1.json.loads(json_str) 把字符串(json串)转成字典 import json # 解析json的 json_str = ''' {"name":" ...
- 用express框架实现反向代理
目前很多公司开发都是前后台分离开发,于是我用node起了一个服务,用node中的express框架实现了反向代理.(通俗易懂的讲就是我在我的电脑访问不到后台同事的电脑接口,这样做以后就可以在我本地访问 ...
- JZOJ 5793. 【NOIP2008模拟】小S练跑步
5793. [NOIP2008模拟]小S练跑步 (File IO): input:run.in output:run.out Time Limits: 2000 ms Memory Limits: ...
- Python 格式化
数字前面补0 字符型: print('23'.zfill(5)) 数字型: print('%011d' % 124) 日期与str互转: datetime 转 str str_date = datet ...
- Spark性能优化:资源调优篇
在开发完Spark作业之后,就该为作业配置合适的资源了.Spark的资源参数,基本都可以在spark-submit命令中作为参数设置.很多Spark初学者,通常不知道该设置哪些必要的参数,以及如何设置 ...
- hadoop: Shuffle过程详解 (转载)
原文地址:http://langyu.iteye.com/blog/992916 另一篇博文:http://www.cnblogs.com/gwgyk/p/3997849.html Shuffle过程 ...