Pyschools Topic 13 Q 9 csv.writer

时间:2012-05-18 02:32:00

标签: python csv

我为这个练习提出了两个不同的功能。一个使用csv类编写器,另一个使用DictWriter类。两者都通过了列出的预期结果,但它们未通过私人测试用例?

import csv
def csvWriter(filename, records): 
    header = []
    for i in records:
        if len(i) < 1:
          records.remove(i)
    for i in records:
        for v in i:
          if v not in header:
            header.append(v)
    for i in records:
        if len(i) == 0:
            return '0 records processed.'
    test=open(filename,'w') 
    wr = csv.writer(test,header,lineterminator='\n')
    wr.writerow(header)
    for i in records:
        wr.writerow(i.values())
    test.close()
    return '%d records processed.' % len(records)

csvWriter( '文件名',[{ 'A':1, 'B':2},{ '一个':3, 'B':4}]

repr(open('filename')。read())---&gt; 'a,b \ n1,2,\ na,b \ n3,4'检查

'传递了2条记录。' ---&GT; “2条记录通过了。” 检查

私人测试案例---&gt;失败?

2 个答案:

答案 0 :(得分:1)

这个函数在私有测试用例上失败的原因是,可以传递第二个参数,并且值将被写入而不进行排序。

import csv
def csvWriter(filename, records): 
  header = []
  for i in records:
    if len(i) < 1:
      records.remove(i)
  for i in records:
    for v in i:
      if v not in header:
        header.append(v)
  for i in records:
    if len(i) == 0:
      return '0 records processed.'
  test=open(filename,'w') 
  dict_wr = csv.DictWriter(test,header,lineterminator='\n')
  dict_wr.writerow(dict(zip(header,header)))
  for i in records:     
  # Adding in the **sorted** built-in fixed it
    dict_wr.writerow(dict(zip(header,sorted(i.values()))))  
  test.close()
  return '%d records processed.' % len(records)

还是非常粗糙,我们也不想使用csv模块。我要回去改进这个并试一试没有模块。

有什么建议吗?

答案 1 :(得分:0)

导入csv

def csvWriter(文件名,记录):

header = []

f = []
with open(filename, 'w')as new_file:

    csv_writer = csv.writer(new_file,header,lineterminator='\n')

    for line in records:
        if line not in header:
            header.append(sorted(line))
            header.append(sorted(line.values()))
            for x in header:
                if x not in f:
                    f.append(x)
                    csv_writer.writerow(x)
return '%s records processed.' % len(records)