我是龙卷风网络框架的新手。 目前我正在构建一个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()
答案 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