ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

Django实用技巧:如何把数据导出到Excel

2019-05-04 17:52:32  阅读:243  来源: 互联网

标签:实用技巧 users Excel Django num export import csv name


将数据导出到excel是许多web应用程序的常见需求。Python使得一切变得更加容易。但是,无论如何,每当我需要自己去实现时,有一个例子做参考,做起来,将会更加快捷。

实现这个目标有两种方法:

  1. 使用Python的csv模块将数据导出到.csv文件;

  2. 使用名为xlwt的第三方模块将数据导出到.xls文件。

文中,我们将用导出django.contrib.auth.models.User的数据做为示范。


导出数据到CSV文件

简单的方法。不需要安装依赖项,这是一件很好的事情。如果您不需要任何花哨的格式,请使用它。

views.py

import csv
from django.http import HttpResponse
from django.contrib.auth.models import User
def export_users_csv(request):
    response = HttpResponse(content_type='text/csv')
    response['Content-Disposition'] = 'attachment; filename="users.csv"'
    writer = csv.writer(response)
    writer.writerow(['Username', 'First name', 'Last name', 'Email address'])
    users = User.objects.all().values_list('username', 'first_name', 'last_name', 'email')
    for user in users:
        writer.writerow(user)
    return response

urls.py

import views
urlpatterns = [
    ...
    url(r'^export/csv/$', views.export_users_csv, name='export_users_csv'),
]

template.html

<a href="{% url 'export_users_csv' %}">Export all users</a>

在上面的示例中,我在QuerySet中使用values_list有两个原因:第一是只查询需要导出的字段,第二是因为它将返回元组中的数据,而不是模型实例。writerow方法需要一个列表/元组。

另一种方法是:

writer.writerow([user.username, user.first_name, user.last_name, user.email, ])

 

将数据导出到XLS文件

如果您确实需要导出到.xls文件,请使用这个方法。你将能够添加格式为粗体字体、字体大小、定义列大小等。

首先,安装xlwt模块。最简单的方法是使用pip。

 

pip install xlwt

views.py

import xlwt
from django.http import HttpResponse
from django.contrib.auth.models import User
def export_users_xls(request):
    response = HttpResponse(content_type='application/ms-excel')
    response['Content-Disposition'] = 'attachment; filename="users.xls"'
    wb = xlwt.Workbook(encoding='utf-8')
    ws = wb.add_sheet('Users')
    # Sheet header, first row
    row_num = 0
    font_style = xlwt.XFStyle()
    font_style.font.bold = True
    columns = ['Username', 'First name', 'Last name', 'Email address', ]
    for col_num in range(len(columns)):
        ws.write(row_num, col_num, columns[col_num], font_style)
    # Sheet body, remaining rows
    font_style = xlwt.XFStyle()
    rows = User.objects.all().values_list('username', 'first_name', 'last_name', 'email')
    for row in rows:
        row_num += 1
        for col_num in range(len(row)):
            ws.write(row_num, col_num, row[col_num], font_style)
    wb.save(response)
    return response

urls.py

import views
urlpatterns = [
    ...
    url(r'^export/xls/$', views.export_users_xls, name='export_users_xls'),
]

template.html

<a href="{% url 'export_users_xls' %}">Export all users</a>

标签:实用技巧,users,Excel,Django,num,export,import,csv,name
来源: https://www.cnblogs.com/pcent/p/10809130.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有