当前位置:  开发笔记 > 编程语言 > 正文

Python .csv编写器留空行

如何解决《Python.csv编写器留空行》经验,为你挑选了1个好方法。

我查看了互联网上有关使用.csv模块的信息; 还有一些人突出了这个问题,但我还没有找到具体的解决方案.

目前,排序/写入/输出代码的工作范围是它将正确的数据输出到文件,但在正确的数据行之间留下空行.

只是为了给出以下代码的一些背景知识; 我必须只输出每个人的最后3个分数到文件中,我将使用"名称,类"对作为数据库的主键,即我将识别数据库的用户.变量'totalscore','难度','用户名'和'类'已在早期代码中定义(有很多,并且它并不完全相关,所以我没有包含它)

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]))

我想要做到这一点,以便在数据输出到文件时纠正问题,或者在输出不正确之后修复它(即只是根据文件中的位置向上移动行)

如果您需要对问题进行任何澄清,请发表评论,我会尽快回复,谢谢.



1> CodeMonkey..:

我有同样的问题,你必须覆盖行终止符,例如:

csv.writer(f, lineterminator='\n')

行终止符的行为可能是系统特定的.*nix和DOS/Windows表现不同.

我有一台Windows机器,Windows上的普通行终结器是'\ r \n'.如果我使用上面的代码,我得到一个'\ r \n'作为行终止符的文件: 单回车

如果我使用'\ r \n'作为行终止符,我会得到'\ r \n\r \n': 双回车

我猜CSV作家与Windows行结束符(\ r \n")取代了"尼克斯行终止(" \n)的'自动,所以你会得到一个回车在Windows机器上太多了.

编辑:我发现有一个标志应该在Windows机器上使用,我在文档第一次错过了:

如果csvfile是一个文件对象,则必须在平台上打开"b"标志,这会产生影响.

它的措辞不是很重要,所以我希望你能原谅我.

推荐阅读
mobiledu2402852357
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有