01----从文件中读取数据
创建一个实验对象TXT文件格式取名叫test02.TXT 路径为r'E:\Python3.6.4\test01\test02.txt'
最简单的操作 :读取整个文件
>>> file_path='E:\Python3.6.4\test01'
>>> with open(file_path)as file_object:
print(contents)
把文件路径给file_peth
open()返回一个表示文件的对象,python将这个对象存储在后边我们要用的对象中。
那为什么要写with 呢?
with在不需要文件的时候关闭文件,因为我们只调用了open(但是没有调用close),当然也可以调用close(),但是如果程序出错,那就执行不了close()文件,文件就不会关闭。不会关闭的结果~~~~~豹哥不用说吧。
ok f5 走一下 诶怎么出错了?
Traceback (most recent call last):
File "<pyshell#4>", line 1, in <module>
with open(file_path)as file_object:
OSError: [Errno 22] Invalid argument: 'E:\\Python3.6.4\test01'
仔细看一下出错的地方,是不是E:\\
好了不卖关子了,在python中\被视为转义字符,为确保万无一失,应该以原始字符串方式指定路径 即在开头的单引号前加上 r
>>> with open(r'E:\Python3.6.4\test01\test02.txt')as file_object:
contents=file_object.read()
print(contents)
3.1415926
123456789
987654321
正常读取。
02----逐行读取数据
因为某些文件需要我们逐行读取,所以稍微改变一下输出格式就好了
>>> filename =r'E:\Python3.6.4\test01\test02.txt'
>>> with open(filename)as file_object:
for line in file_object:
print(line)
输出格式:
3.1415926
123456789
987654321
是不是有变化,中间多了一行?
什么我弄了这么久想删除间隔??
行,那就删!!!!
>>> filename=r'E:\Python3.6.4\test01\test02.txt'
>>> with open(filename)as file_object:
for line in file_object:
print(line.rstrip ())
作为好奇,豹哥决定查看一下 line . 的方法都有哪些(其实还是字符串方法)
复制于 :http://www.runoob.com/python/python-strings.html
菜鸟教程,这是一个很好的网站,希望大家常去。
python的字符串内建函数
字符串方法是从python1.6到2.0慢慢加进来的——它们也被加到了Jython中。
这些方法实现了string模块的大部分方法,如下表所示列出了目前字符串内建支持的方法,所有的方法都包含了对Unicode的支持,有一些甚至是专门用于Unicode的。
方法 | 描述 |
---|---|
把字符串的第一个字符大写 | |
返回一个原字符串居中,并使用空格填充至长度 width 的新字符串 | |
返回 str 在 string 里面出现的次数,如果 beg 或者 end 指定则返回指定范围内 str 出现的次数 | |
以 encoding 指定的编码格式解码 string,如果出错默认报一个 ValueError 的 异 常 , 除非 errors 指 定 的 是 'ignore' 或 者'replace' | |
以 encoding 指定的编码格式编码 string,如果出错默认报一个ValueError 的异常,除非 errors 指定的是'ignore'或者'replace' | |
检查字符串是否以 obj 结束,如果beg 或者 end 指定则检查指定的范围内是否以 obj 结束,如果是,返回 True,否则返回 False. | |
把字符串 string 中的 tab 符号转为空格,tab 符号默认的空格数是 8。 | |
检测 str 是否包含在 string 中,如果 beg 和 end 指定范围,则检查是否包含在指定范围内,如果是返回开始的索引值,否则返回-1 | |
格式化字符串 | |
跟find()方法一样,只不过如果str不在 string中会报一个异常. | |
如果 string 至少有一个字符并且所有字符都是字母或数字则返 回 True,否则返回 False | |
如果 string 至少有一个字符并且所有字符都是字母则返回 True, 否则返回 False | |
如果 string 只包含十进制数字则返回 True 否则返回 False. | |
如果 string 只包含数字则返回 True 否则返回 False. | |
如果 string 中包含至少一个区分大小写的字符,并且所有这些(区分大小写的)字符都是小写,则返回 True,否则返回 False | |
如果 string 中只包含数字字符,则返回 True,否则返回 False | |
如果 string 中只包含空格,则返回 True,否则返回 False. | |
如果 string 是标题化的(见 title())则返回 True,否则返回 False | |
如果 string 中包含至少一个区分大小写的字符,并且所有这些(区分大小写的)字符都是大写,则返回 True,否则返回 False | |
以 string 作为分隔符,将 seq 中所有的元素(的字符串表示)合并为一个新的字符串 | |
返回一个原字符串左对齐,并使用空格填充至长度 width 的新字符串 | |
转换 string 中所有大写字符为小写. | |
截掉 string 左边的空格 | |
maketrans() 方法用于创建字符映射的转换表,对于接受两个参数的最简单的调用方式,第一个参数是字符串,表示需要转换的字符,第二个参数也是字符串表示转换的目标。 | |
返回字符串 str 中最大的字母。 | |
返回字符串 str 中最小的字母。 | |
有点像 find()和 split()的结合体,从 str 出现的第一个位置起,把 字 符 串 string 分 成 一 个 3 元 素 的 元 组 (string_pre_str,str,string_post_str),如果 string 中不包含str 则 string_pre_str == string. | |
把 string 中的 str1 替换成 str2,如果 num 指定,则替换不超过 num 次. | |
类似于 find()函数,不过是从右边开始查找. | |
类似于 index(),不过是从右边开始. | |
返回一个原字符串右对齐,并使用空格填充至长度 width 的新字符串 | |
string.rpartition(str) | 类似于 partition()函数,不过是从右边开始查找. |
删除 string 字符串末尾的空格. | |
以 str 为分隔符切片 string,如果 num有指定值,则仅分隔 num 个子字符串 | |
按照行('\r', '\r\n', \n')分隔,返回一个包含各行作为元素的列表,如果参数 keepends 为 False,不包含换行符,如果为 True,则保留换行符。 | |
检查字符串是否是以 obj 开头,是则返回 True,否则返回 False。如果beg 和 end 指定值,则在指定范围内检查. | |
在 string 上执行 lstrip()和 rstrip() | |
翻转 string 中的大小写 | |
返回"标题化"的 string,就是说所有单词都是以大写开始,其余字母均为小写(见 istitle()) | |
根据 str 给出的表(包含 256 个字符)转换 string 的字符, 要过滤掉的字符放到 del 参数中 | |
转换 string 中的小写字母为大写 | |
返回长度为 width 的字符串,原字符串 string 右对齐,前面填充0 | |
isdecimal()方法检查字符串是否只包含十进制字符。这种方法只存在于unicode对象。 |
运行结果大家都猜到了~~~
03----包含文件各行的列表
>>> filename=r'E:\Python3.6.4\test01\test02.txt'
>>> with open(filename)as file_object:
for line in file_object:
print(line.rsplit ())
['3.1415926']
['123456789']
['987654321']
Python split() 通过指定分隔符对字符串进行切片,如果参数 num 有指定值,则仅分隔 num 个子字符串
04----使用文件的内容
这个时候交付环境就容易出错了
就需要 ctrl+n 新建 文件了
#使用文件的内容
filename=r'E:\Python3.6.4\test01\test02.txt'
with open(filename)as file_object:
lines=file_object.readlines()
#创建变量,存储我们要用的数值
pi_string=''
#使用一个循环将各行都能加入pi_string,并删除末尾换行符
for line in lines:
pi_string += line.strip ()
#打印字符串
print(pi_string)
#输出这个字符串的长度
print(len(pi_string))
===================== RESTART: E:/Python3.6.4/使用文件的内容.py =====================
3.1415926123456789987654321
27
>>>
当然,读取文件的时候