2017-05-05 40 views
0

我从表单上传CSV文件,并希望在Python中检索其第一行。我在App Engine应用程序上,并使用webapp2(不知道它是否相关?)。在谷歌应用程序引擎中上传和读取CSV文件

我尝试了很多在论坛上找到的答案,但都没有工作。我想:

def post(self): 
    csv_file = self.request.POST.get('csvFile') 
    fileReader = csv.reader(csv_file.file) 

,但我得到:AttributeError: 'unicode' object has no attribute 'file'

我也试过:

def post(self): 
    csvFile = self.request.get('csvFile') 
    print csvFile 

    stringReader = csv.reader(StringIO.StringIO(csvFile)) 
    for row in stringReader: 
     print row 

,但我得到:

C:\fakepath\my_file.csv ['C:\\fakepath\\my_file.csv']

为我打印语句(无论是我做request.get或request.POST.get)。

我也试过:

def post(self): 
    content = self.request.POST.multi['csvFile'].file.read() 

,但我得到:AttributeError: 'str' object has no attribute 'file'

我也试过:

def post(self): 
    csvFile = self.request.files['csvFile'] 
    file = open(csvFile, 'r') 

,但我得到:AttributeError: files

我也试过:

def post(self): 
    csvFile = self.request.POST['csvFile'].value.decode('utf-8') 
    file = csvFile.splitlines() 
    data = csv.DictReader(file) 

,但我得到:AttributeError: 'unicode' object has no attribute 'value'

因为许多这些解决方案似乎为其他人工作,我不明白这些错误。

我的形式看起来像这样(我用聚合物):

<form is="iron-form" action="/upload" method="POST" enctype="multipart/form-data" 
          on-iron-form-submit="_formSubmitted" id="form" name="form"> 

         <div class="box"> 
          <input type="file" name="csvFile" id="file" class="inputfile" 
            data-multiple-caption="{count} files selected" multiple on-tap="_chooseFile"/> 
          <label for="file" name="label"> 
           <span>Choose a CSV file...</span></label> 

         </div> 

你有什么建议? 谢谢!

回答

0

我终于发现问题:它来自Polymer,对象'铁形式'不支持enctype="multipart/form-data"。我删除了is="iron-form"和所有工作正常。