Python .csv编写器留空行

时间:2015-12-15 12:31:53

标签: python csv io

我查看了互联网上有关使用.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]))

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

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

1 个答案:

答案 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”标志打开,这会产生影响。

它的措辞并不是那么重要,所以我希望你能原谅我。