在龙卷风Web框架中读取csv文件

时间:2012-08-28 04:32:24

标签: python csv tornado

我是龙卷风网络框架的新手。 目前我正在构建一个Web应用程序,应该加载csv文件然后处理它。我尝试在python中使用csv模块,并尝试了表格模块,这对我没有帮助。

所以,我的问题是,是否有任何包或开源库将读取csv文件数据并将其存储在某种变量类型中,以便我可以对该文件执行各种操作。

我收到以下错误:

raise ValueError, "Need formats argument"

我的代码是:

import re
import sys
import os.path
import tornado.httpserver
import webbrowser
import personalfile
import tabular as tb
import csv

try:
    import tornado.ioloop
    import tornado.web
except:
    print 'No tornado module installed, Please install the tornado from http://www.tornadoweb.org/'
    sys.exit()

SRC = os.path.dirname(__file__)

# Main Handler
class MainHandler(tornado.web.RequestHandler):
    def get(self):
        self.render("static/template_upload.html")



class OutputHandler(tornado.web.RequestHandler):
    def post(self):
        template_file = self.get_argument('template_html', None)
        **data_file = self.get_argument('csvfile', None)
        data_file = csv.DictReader(data_file)**
        data_file = tb.tabarray(data_file, verbosity=0, headerlines=1)
        xhtmlOutput = personalfile.function([templatehtmlfile,data_file])

        self.render('output.xhtml', data = xhtmlOutput)


application = tornado.web.Application([
    (r"/", MainHandler),
    (r"/output", OutputHandler)
], debug=True,
   static_path=os.path.join(SRC, "static")
)



if __name__ == "__main__":
    print open(os.path.join(SRC, 'static', 'intro.txt')).read()
    webbrowser.open('http://127.0.0.1:8888')

    application.listen(8888)
    tornado.ioloop.IOLoop.instance().start()

2 个答案:

答案 0 :(得分:5)

这不是csv.DictReader对象的工作原理[module docs]。你只是做了读者,而不是实际提取任何数据。如果您希望存储所有数据,则必须实际读取它。例如:

>>> import csv
>>> with open("test.csv") as fp:
...     reader = csv.reader(fp)
...     data = list(reader)
... 
>>> data
[['a', 'b', 'c'], ['1', '2', '3'], ['4', '5', '6']]
>>> 
>>> with open("test.csv") as fp:
...     reader = csv.DictReader(fp)
...     data = list(reader)
... 
>>> data
[{'a': '1', 'c': '3', 'b': '2'}, {'a': '4', 'c': '6', 'b': '5'}]

等等。您是否确实需要一次性获取所有数据取决于您的代码。

答案 1 :(得分:0)

我的代码中有错误。您上传的文件可从self.request.files

获取

参考:http://www.tornadoweb.org/documentation/overview.html