1

我为此练习提出了两种不同的功能。一种使用 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},{'a':3,'b':4}]

repr(open('filename').read()) ---> 'a,b\n1,2,\na,b\n3,4'检查

“通过了 2 条记录。” ---> '2 条记录通过。' 查看

私人测试用例 ---> 失败?

4

2 回答 2

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 模块。我将回去改进这一点,并在没有模块的情况下试一试。

有什么建议么?

于 2012-05-22T19:16:39.763 回答
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)
于 2020-08-05T20:01:58.833 回答