我對Python很新。我需要創建一個將csv數據加載到字典中的類。python csv into dictionary
我想能夠控制鍵和值 因此,讓我們說下面的代碼,我可以隨時拔出worker1.name或worker1.age。
class ageName(object):
'''class to represent a person'''
def __init__(self, name, age):
self.name = name
self.age = age
worker1 = ageName('jon', 40)
worker2 = ageName('lise', 22)
#Now if we print this you see that it`s stored in a dictionary
print worker1.__dict__
print worker2.__dict__
#
'''
{'age': 40, 'name': 'jon'}
#
{'age': 22, 'name': 'lise'}
#
'''
#
#when we call (key)worker1.name we are getting the (value)
print worker1.name
#
'''
#
jon
#
'''
但我被困在加載我的csv數據到鍵和值。
[1]我要創造我自己的鍵 worker1 = ageName([名],[年齡],[ID],[兩性])
[2]每[名],[年齡] ,[id]和[gender]來自csv數據文件中特定的一列
我真的不知道如何處理這個問題。我嘗試了很多方法,但是失敗了。我需要一些幫助才能開始。
----編輯 這是我原來的代碼
import csv
# let us first make student an object
class Student():
def __init__(self):
self.fname = []
self.lname = []
self.ID = []
self.sport = []
# let us read this file
for row in list(csv.reader(open("copy-john.csv", "rb")))[1:]:
self.fname.append(row[0])
self.lname.append(row[1])
self.ID.append(row[2])
self.sport.append(row[3])
def Tableformat(self):
print "%-14s|%-10s|%-5s|%-11s" %('First Name','Last Name','ID','Favorite Sport')
print "-" * 45
for (i, fname) in enumerate(self.fname):
print "%-14s|%-10s|%-5s|%3s" %(fname,self.lname[i],self.ID[i],self.sport[i])
def Table(self):
print self.lname
class Database(Student):
def __init__(self):
g = 0
choice = ['Basketball','Football','Other','Baseball','Handball','Soccer','Volleyball','I do not like sport']
data = student.sport
k = len(student.fname)
print k
freq = {}
for i in data:
freq[i] = freq.get(i, 0) + 1
for i in choice:
if i not in freq:
freq[i] = 0
print i, freq[i]
student = Student()
database = Database()
這是我當前的代碼(不完全)
import csv
class Student(object):
'''class to represent a person'''
def __init__(self, lname, fname, ID, sport):
self.lname = lname
self.fname = fname
self.ID = ID
self.sport = sport
reader = csv.reader(open('copy-john.csv'), delimiter=',', quotechar='"')
student = [Student(row[0], row[1], row[2], row[3]) for row in reader][1::]
print "%-14s|%-10s|%-5s|%-11s" %('First Name','Last Name','ID','Favorite Sport')
print "-" * 45
for i in range(len(student)):
print "%-14s|%-10s|%-5s|%3s" %(student[i].lname,student[i].fname,student[i].ID,student[i].sport)
choice = ['Basketball','Football','Other','Baseball','Handball','Soccer','Volleyball','I do not like sport']
lst = []
h = 0
k = len(student)
# 23
for i in range(len(student)):
lst.append(student[i].sport) # merge together
for a in set(lst):
print a, lst.count(a)
for i in set(choice):
if i not in set(lst):
lst.append(i)
lst.count(i) = 0
print lst.count(i)
請注意,如果您確實需要字典,則不能使用'worker1.name'來獲取值。字典可以用'worker1 ['name']'的形式訪問。那麼,你真的想要哪個? – 2009-12-14 00:13:07
嗨,彼得。我很抱歉,我非常感謝您的評論。這是個好問題。任何親和好?我很抱歉... – CppLearner 2009-12-14 00:18:39
總有利弊,但您要求提供字典。你的意思是你不知道你是否應該使用一個?爲了回答這個問題,我們需要更多地瞭解你將如何處理數據。 – 2009-12-14 00:54:14