Python把对应格式的csv文件转换成字典类型存储脚本的方法
作者:坏蛋是我 时间:2022-07-08 08:39:06
该脚本是为了结合之前的编写的脚本,来实现数据的比对模块,实现数据的自动化!由于数据格式是定死的,该代码只做参考,有什么问题可以私信我!
CSV的数据格式截图如下:
readDataToDic.py源代码如下:
#coding=utf8
import csv
'''
该模块的主要功能,是根据已有的csv文件,
通过readDataToDicl函数,把csv中对应的部分,
写入字典中,每个字典当当作一条json数据
'''
class GenExceptData(object):
def __init__(self):
try:
#用来存放json数据的字典
self.dataDic={}
#存放csv中读取的数据
self.mdbuffer=[]
#打开csv文件,设置读的权限
csvHand=open("20170510174450.csv","r")
#创建读取csv文件句柄
readcsv=csv.reader(csvHand)
#把csv的数据读取到mdbuffer中
for row in readcsv:
self.mdbuffer.append(row)
#把数据穿件为为字典类型的
self.readDataToDicl()
#保存文件
except Exception,e:
print "Read Excel error:",e
finally:
#关闭csv文件
csvHand.close()
def readDataToDicl(self):
try:
#获取mdbuffer中的元素个数
rowNumber=len(self.mdbuffer)
#设置当前行号
currentrow=1
#设置json数据的属性值
propertyJson={}
#读取列表中的元素
for row in range(1,rowNumber):
#创建一个临时变量用来存取一次循环的属性键值
temp={}
#获取列表中一个元素
item=self.mdbuffer[row]
#获取当前元素,当前元素代表的是每个
#事件起始的位置
currentItem=self.mdbuffer[currentrow]
#获取serviceId并进行解码
serviceId= currentItem[2].decode("gbk")
#获取属性并进行解码,把解码的值存入propertyName
propertyName=item[3].decode("gbk")
#获取属性值并进行解码,把解码的值存入propertyValue
propertyValue=item[4].decode("gbk")
#判断埋点事件与serviceId是否相等
if item[0]==currentItem[0] and item[2]==currentItem[2]:
#把serviceId方式字典propertyJson中
propertyJson["serviceId"]=serviceId
#把属性/值对放入temp字典中
temp[propertyName]=propertyValue
#调用字典的update函数,把temp中的键值对
#添加到 propertyJson字典中
propertyJson.update(temp)
#使用continue,如果为if条件为true则循环执行if语句模块
continue
else:
#把行号设置为当前行
currentrow=row
#把当前的属性解码放入propertyName
propertyName=currentItem[3].decode("gbk")
#把当前的属性值解码放入propertyName
propertyValue=currentItem[4].decode("gbk")
#把serviceId方式字典propertyJson中
propertyJson["serviceId"]=serviceId
#把属性/值对放入propertyJson字典中
propertyJson[propertyName]=propertyValue
#输入字典中的值,并对值进行解码
#该部分用于调试使用
for key,val in propertyJson.items():
print key,"=",val.encode("utf8")
print "#"*50
#为下次做准备,清除字典中的元素
propertyJson.clear()
except Exception,e:
print "Reading Data TO Dic Error:",e
def test():
GenExceptData()
if __name__=="__main__":
test()
运行结果图:
来源:https://blog.csdn.net/henni_719/article/details/74930674
标签:Python,csv,字典


猜你喜欢
PHPMailer发送HTML内容、带附件的邮件实例
2024-05-11 10:07:43

JavaScript实现x秒后自动跳转到一个页面
2024-04-18 10:00:55
Python中各类Excel表格批量合并问题的实现思路与案例
2022-12-21 14:30:01

Python生成rsa密钥对操作示例
2021-08-25 03:43:31
python开根号实例讲解
2022-10-03 12:29:07
PHP中Trait及其应用详解
2023-11-24 06:33:05

深入讲解Go语言中函数new与make的使用和区别
2023-06-16 17:52:29
Python爬虫工具requests-html使用解析
2021-10-23 02:20:27

利用Python和C语言分别实现哈夫曼编码
2021-08-12 09:59:49

CentOS中升级Python版本的方法详解
2021-08-22 20:22:30
如何快捷地实现分页显示功能?
2010-01-01 15:08:00
教你如何使用Python Tkinter库制作记事本
2023-06-27 21:57:30

JavaScript中跨域问题的深入理解
2024-04-28 09:41:55

Python使用Pygame绘制时钟
2022-08-04 14:10:07

js实现砖头在页面拖拉效果
2024-05-22 10:40:24

Python容器类型转换的3种方法实例
2022-06-03 13:32:32

Python使用背景差分器实现运动物体检测
2023-06-21 09:37:22

9种使用Chrome Firefox 自带调试工具调试javascript技巧
2023-07-19 01:03:48

oracle指定排序的方法详解
2023-07-14 15:36:28
Python类的用法实例浅析
2023-07-31 11:17:18