我查看了互联网上有关使用.csv模块的信息;还有一些人突出了这个问题,但我还没有找到具体的解决方案。
目前,排序/编写/输出代码的工作范围是它将正确的数据输出到文件,但在正确的数据行之间留下空行。
为了给出以下代码的一些背景知识;我必须只输出每个人的最后3个分数到文件中,我将使用'姓名,班级' pair作为数据库的主键,即我将识别数据库的用户。变量'总计' ,'难度' ,'用户名'和'班级'已经在早期的代码中定义了(很多,并且它并不完全相关,所以我还没有包含它)
savescore = 0
savescore = totalscore * (difficulty + 2) #Multiplies their score out of 10 by difficulty + 2
print("You got " + str(totalscore) + " Out of ten and scored " + str(savescore) + " points" )
with open("Scoredatabase.csv","r") as f:
f=csv.reader(f)
NameClassScoreList = []
for line in f:
NameClassScoreList.append(line[0:5]) # Creates a list of all of the entries in the .csv file (List of lists) in the order Name,Class,Score,Score,Score
NameClassList = []
for n in NameClassScoreList:
NameClassList.append([n[0], n[1]]) #Appends a list of pairs of (Name,Class) for all the records in the .csv file
print(NameClassList)
print(NameClassScoreList)
userNameClass=[]
userNameClass=[username,Class] #Creates a variable storing the pair (Name,Class) for the user currently using the program, can later be used to compare with ones in the database
if userNameClass not in NameClassList: #Tests if a user with that username and class already exists (It should append it to the end before sorting)
NameClassScoreList.append([username,Class,str(savescore),'0','0'])
for entry in NameClassScoreList: #Iterates through all of the entries within the NameClassScoreList (Which includes a list of entries in the .csv file)
if entry[0:2] == [username,Class]: #Checks if the username,Class matches
entry[4]=entry[3] #If it does, it moves all of the scores forwards, deleting the the 3rd last and then replaces it with the savescore
entry[3]=entry[2]
entry[2]=str(savescore)
NameClassScoreList = sorted(NameClassScoreList, key=itemgetter(1,0)) #Sorts the NameClassScoreList by Class, then Name alphabetically.
with open("Scoredatabase.csv","w") as f:
writer=csv.writer(f) #should be for n in NameClassScoreList
for entryrow in NameClassScoreList:
writer.writerow((entryrow[0],entryrow[1],entryrow[2],entryrow[3],entryrow[4]))
我想要做到这一点,以便在数据输出到文件时纠正问题,或者在输出不正确之后修复它(即只是根据它们在的位置向上移动行。文件)
如果您需要对此问题进行任何澄清,请发表评论,我会尽快回复,谢谢。
答案 0 :(得分:5)
我有同样的问题,你必须覆盖行终止符,例如:
csv.writer(f, lineterminator='\n')
行终止符的行为可能是系统特定的。 * nix和DOS / Windows表现不同。
我有一台Windows机器,Windows上的普通行终结器是'\ r \ n'。如果我使用上面的代码,我得到一个'\ r \ n'作为行终止符的文件: Single carriage return
如果我使用'\ r \ n'作为行终止符,我会得到'\ r \ n \ n \ n': Double carriage return
我猜csv编写器会自动用windows行终结符('\ r \ n')替换'nix行终止符('\ n'),因此在Windows机器上会有一个回车太多。
编辑:我发现应该在Windows机器上使用flag,我第一次在文档中错过了这个:如果csvfile是一个文件对象,那么它必须在平台上以“b”标志打开,这会产生影响。
它的措辞并不是那么重要,所以我希望你能原谅我。