python之读取文件的测试数据
假设我们有一个叫testdata.txt的文件,现在在这个文件里面有测试数据,我们怎么利用前2小章学习的知识,读取测试数据呢?
测试数据如下:
url:https://www.cnblogs.com/wlyhy/,e-mail:wurz529@foxmail.com,username:11111111
url:https://www.baidu.com/,e-mail:wurz529@163.com,usernamfore:22222222.
博主刚刚试了一下,刚接触python遇到这个问题挺烧脑的。建议从问题入手,问题说要读取测试数据。我们在测试数据中看到,都是xxx:xxxxxx的形式,是不是非常像python字典中的key:value对应模式。如果测试数据只有一行,那我们用字典完全可以。如果测试数据有多行,只用一个字典的话,key会重复,倒是覆盖问题,要解决可以采用列表。最后的输出格式就是[{},{},.....{}]这种格式。因此需要定义list,以及dict.既然输出格式确定了,那么怎么把测试数据放到这个格式呢?以第一行来看,这是一长串字符串。我们需要的元素中间以","分隔,那么想办法将","分割出去,就是字符串的split方法,split(","),通过split方法得到的是列表,这样子,我们的3个key:value就被存在列表中,形式如下["url:https://www.cnblogs.com/wlyhy/", "e-mail:wurz529@foxmail.com", "username:11111111"]。我们再以其中一个来看,":"前面是我们需要的key,":"后面则是我们需要的value,我们再次split切割,得到["url","xxxx"]这样子的格式。只差最后一步就到字典了,就是dict[list[0]] = list[1],就可以得到{"url":"xxxxxx"}了。至于一行中其他的,可以同样方法得到。所有行的字典都有了之后,通过list.append方法,加入这个大的list就行了。
实现如下:
- #!/usr/bin/python3
- # -*- coding: utf-8 -*-
- # @Time :2018/11/29 15:07
- # @Author :Yosef
- # @Email :wurz529@foxmail.com
- # @File: :class31.py
- # @Software :PyCharm Community Edition
- def read_file(filename):
- file = open(filename,"r+")
- list_1=[]
- for items in file.readlines():
- dict_1={}
- for item in items.strip("\n").split(","): # 去除首尾空格,然后切割中间“,”得到list
- dict_1[item.split(":",1)[0]]=item.split(":",1)[1] # 原型:dict[key]=value and list.split["",](得到list)
- list_1.append(dict_1)
- print(list_1)
- return list_1
- read_file("testdata.txt")
结果:
python之读取文件的测试数据的更多相关文章
- python在读取文件时出现 'gbk' codec can't decode byte 0x89 in position 68: illegal multibyte sequence
python在读取文件时出现“UnicodeDecodeError:'gbk' codec can't decode byte 0x89 in position 68: illegal multiby ...
- [Head First Python]4.读取文件datafile.txt, 去除两边空格, 存储到列表,从列表格式化(nester.py)后输出到文件man.out,other.out
datafile.txt #文件 Man: this is the right room for an argument. Other Man: I've told you once. Man: N ...
- python中读取文件数据时要注意文件路径
我们在用python进行数据处理时往往需要将文件中的数据取出来做一些处理,这时我们应该注意数据文件的路径.文件路径不对,回报如下错误: FileNotFoundError: File b'..Adve ...
- python中读取文件的read、readline、readlines方法区别
#读取文件所有内容,返回字符串对象,python默认以文本方式读取文件,遇到结束符读取结束. fr = open('lenses.txt')read = fr.read()print(type(rea ...
- python 顺序读取文件夹下面的文件(自定义排序方式)
我们在读取文件夹下面的文件时,有时是希望能够按照相应的顺序来读取,但是 file_lists=os.listdir()返回的文件名不一定是顺序的,也就是说结果是不固定的.就比如读取下面这些文件,希望能 ...
- python 逐行读取文件的三种方法
方法一: 复制代码代码如下: f = open("foo.txt") # 返回一个文件对象 line = f.readline() ...
- Python逐行读取文件内容
更详细的文件按行读取操作可以参考:http://www.cnblogs.com/xuxn/archive/2011/07/27/read-a-file-with-python.html 一行一行得从文 ...
- Python中读取文件输出时在头部输出\ufeff
问题出现: 在我测试python中的文本文件的读取与写入时,用到了字典对象来存储读出的数据. std_data = dict() with open(sys.argv[1], encoding='UT ...
- python工具 - 读取文件的部分指定内容并输出到外置窗口
一.使用场景 某些配置文件里有一些特定的字符,而这些字符恰巧需要我们采集出来,然后输出到另外一个窗口做展示时,可以使用该工具. 本例的演示则提取配置文件中的[姓名:黄蓉 女 九阴真经.姓名:郭靖 男 ...
随机推荐
- 2-2 groovy基础知识-理论介绍
- HDU 5293 Tree chain problem
树状数组 + dp 设$f_i$表示以$i$为根的子树中的能选取的最大和,$sum_x$表示$\sum_{f_y}$ ($y$是$x$的一个儿子),这样子我们把所有给出的链按照两点的$lca$分组, ...
- 用Linq取两个数组的差集
两个数组,取其差集,用Linq做比较方便,效率也比较高,具体如下示例 有两个数组list1 和list2 ,如下 List<int> list1 = new List<int> ...
- html页面的局部刷新
有时候我们在做一个动态/静态网页,网页中的某部分需要从服务器获取值但是不能把整个页面都提交到服务器,也就是要对页面做局部刷新,也就是对整个网页无刷新更新值.在这种情况下就需要用JS和XMLHttpRe ...
- codefirst 最新策略
http://www.yunjuu.com/info/76058.html 在原有数据库中使用 CodeFirst ,除了第一次添加实体后要立即执行一次 Enable-Migrations add-m ...
- MFC可视化 列表控件的使用
1.应该加入头文件 #include <Atlbase.h> 2.示例 类向导给列表控件绑定变量m_list DWORD dwExStyle=LVS_EX_FULLRO ...
- EBS登陆界面个性化
把完整资料贴出来 Set the profile option Local Login Mask (FND_SSO_LOCAL_LOGIN_MASK). (This profile option is ...
- HackThirteen 在onCreate()方法中获取View的宽度和高度
1.概要: Android源代码中很多模块都使用了post()方法,深入理解框架曾运行机制对于避开类似于本例中的小陷阱是很重要的 2.问题提出: 如果开发一些依赖于UI控件的宽和高的功 ...
- Nginx配置 简单写了个
#user nobody;worker_processes 1; #error_log logs/error.log;#error_log logs/error.log notice;#error_l ...
- 如何彻底删除TFS上的团队项目 For VS 2017
参考 Visual Studio 2017 TFSDeleteProject.exe 位置 X:\Program Files (x86)\Microsoft Visual Studio\2017\En ...