如何在HTML页面中显示CSV文件的所有数据?

2024-05-16 04:10:58 发布

您现在位置:Python中文网/ 问答频道 /正文

我在django中有一个读取csv文件并将其数据存储在数据库中的代码,我打算在HTML页面中显示数据,这是我的视图:

def addbulkuser(request):                                                                                  
prompt = {                                                                                             
    'order': 'Order of the file should be: Username, First name, Last name, Email & Password'          
}                                                                                                      

if request.method == "GET":                                                                            
    return render(request, 'andon/user_form_bulk.html', prompt)                                        

data_file = request.FILES['file']                                                                      

if not data_file.name.endswith('.csv'):                                                                
    messages.error(request, 'This is not a csv file')                                                  

if data_file.name.endswith('.csv'):                                                                    
    data_set = data_file.read().decode('UTF-8')                                                        
    io_string = io.StringIO(data_set)                                                                  
    next(io_string)                                                                                    
    for column in csv.reader(io_string, delimiter=',', quotechar="|"):                                 
        created = User.objects.update_or_create(                                                       
            username=column[0],                                                                        
            first_name=column[1],                                                                      
            last_name=column[2],                                                                       
            email=column[3],                                                                           
            password=column[4],                                                                        
            last_login=datetime.now(),                                                                 
        )                                                                                              

        user = User.objects.get(username=column[0])                                                    
        user.set_password(user.password)                                                               
        user.save()                                                                                    
        andon_user_group = Group.objects.get(name='andon_user')                                        
        andon_user_group.user_set.add(user)                                                            
    col = column                                                                                       
    colu = messages.success(request, 'Users added successfully')                                       
    context = {'col': col,                                                                             
               'colu': colu                                                                            
               }                                                                                       
    return render(request, 'andon/user_form_bulk.html', context)                                       

return render(request, 'andon/user_form_bulk.html')    

变量“”col“包含csv文件中的所有数据,我在HTML中这样调用它:

{% for column in col %}
        {{ column }}
    {% endfor %}

但它只在html中显示CSV文件中的最后一个数据,我如何显示所有数据

问候


Tags: 文件csv数据nameiodataifrequest
1条回答
网友
1楼 · 发布于 2024-05-16 04:10:58

您的代码当前只将CSV文件中的最后一个数据保存到变量col,因此这是上下文中传递的唯一数据

如果要显示所有数据,可以考虑创建一个列表列表,其中每个列表将包含个人的数据

例如,这是可以合并到程序中的方法之一

listoflists = []
for column in csv.reader(io_string, delimiter=',', quotechar="|"):
    sublist = []
    for j in range(0,6)
        sublist.append(column[j])
    listoflists.append(sublist)

context = {'col': listoflists,                                                                             
            'colu': colu                                                                            
          }                                                                                       
return render(request, 'andon/user_form_bulk.html', context)  

在模板中,您可以通过以下方式访问它:

{% for values in col %}
  {% for value in values %}
    The value is {{value}}
  {% endfor %}
{% endfor %}

相关问题 更多 >