一.先写导出按钮接口

  1.此接口对用户权限进行判断

  2.此接口将前端的参数组合拼凑到下一个接口的url中去,用于条件筛选

  3.用户有权限的情况下将用户的权限信息保存到redis中去,并将token写到url的参数中,以便对用户下载时权限的验证

class ExportInfoButtonView(APIView):
permission_classes = [SupserPermisson,] def get(self, request,pk):
res = {'error':'','success':''} cinema_obj = Cinema.objects.filter(cinema_code=pk)
if not cinema_obj:
res['error'] = '信息不存在'
return JsonResponse(data=res, code=400, desc="success", status=status.HTTP_400_BAD_REQUEST)
params_dic=dict(request.query_params)
del_keys=[]
for i in params_dic:
if params_dic[i][0] == '':
del_keys.append(i)
else:
params_dic[i] = params_dic[i][0]
if del_keys:
for key in del_keys:
params_dic.pop(key)
params_dic['token'] = make_token(request.user.username)
params = urlencode(params_dic,encoding='utf8')
data = {}
data['url'] = '127.0.0.1:8000/test/export_info_excel/{0}?{1}'.format(pk,params)
res['success'] = data
return JsonResponse(data=res, code=200, desc="success", status=status.HTTP_200_OK)

1.1 说明:创建token 和验证token的函数

import time
import hashlib
import redis
from ticket_audit import settings_sample
redis_obj = redis.Redis(host=settings_sample.REDIS_HOST, port=settings_sample.REDIS_PORT) def make_token(user): #创建token的函数 返回一个有过期时间的token
ti=str(time.time())
md5_obj = hashlib.md5(ti.encode('utf8'))
md5_obj.update(user.encode('utf8'))
token=md5_obj.hexdigest()
print(token)
redis_obj.set(token,'',ex=20)
return token def check_token(token): #token 验证函数,验证带过来的token是否在redis中存在
print(redis_obj.get(token),'这是题啃=======')
if redis_obj.get(token):
return True
return False

二.下载接口

class ExportCinemaMovieExcelView(GenericAPIView):
serializer_class = InfoSerializers
queryset = Info.objects.all()
filter_backends = (DjangoFilterBackend,)
filter_class = InofFilter def get(self, request, pk):
res = {'error': '', 'success': {}}
token = request.query_params.get('token', None)
     #验证用户token
if not token or not check_token(token):
res['error'] = '用户没有权限'
return JsonResponse(data=res, code=401, desc="success", status=status.HTTP_401_UNAUTHORIZED)
info_obj = Info.objects.filter(code=pk)
if not cinfo_obj:
res['error'] = '不存在'
return JsonResponse(data=res, code=400, desc="success", status=status.HTTP_400_BAD_REQUEST) dic,_ = info_data_to_dict(pk, report_data, data1, data2)
     #获取到数据之后 将数据写入到excel中去
name,file_name = export_cinema_movie_excel(dic)
    #读取刚刚写好的excel文件 并将文件返回给前端
with open(name, 'rb') as model_excel:
result = model_excel.read()
response = HttpResponse(result)
response['Content-Disposition'] = 'attachment; filename=%s'%file_name
os.remove(name)
return response

2.1函数export_cinema_movie_excel

from io import BytesIO,StringIO

import datetime

# 定义时间标志变量
import xlwt as xlwt
from django.http import HttpResponse def expor_info_excel(result):
sheet_time = datetime.datetime.now()
sheet_mark = sheet_time.strftime('%Y-%m-%d')
book_mark = sheet_time.strftime('%Y%m%d') # 查询数据结果和字段名字 赋值给两个变量
result = result #查询的数据信息 fields = ['a','b','c','d','e','f','试试人数','生物偏差','城市偏差'] # 查询到的标题描述信息 response = HttpResponse(content_type='application/vnd.ms-excel') # 指定返回为excel文件
response['Content-Disposition'] = 'attachment;filename=cinema_movie_%s.xls' %book_mark # 指定返回文件名
wb = xlwt.Workbook(encoding='utf-8') # 设定编码类型为utf8
sheet = wb.add_sheet(sheet_mark) # excel里添加类别 for field in range(0,len(fields)):
sheet.write(0,field,fields[field])
#数据坐标0,0 ~ row,col row取决于:result的行数;col取决于fields的总数
# for row in range(1,len(result)+1):
row = 1
j = 1
while row <= len(result):
for i in result:
sheet.write(row, 0, j)
sheet.write(row, 1, i)
sheet.write(row, 2, result[i].get('num_a',None))
sheet.write(row, 3, result[i].get('num_b',None))
sheet.write(row, 4, result[i].get('report_c',None))
sheet.write(row, 5, result[i].get('num_d',None))
sheet.write(row, 6, result[i].get('num_r',None))
sheet.write(row, 7, result[i].get('report_f',None))
sheet.write(row, 8, result[i].get('report_g',None))
row += 1
j += 1 import os
name=os.getcwd()+'/temp/cinema_movie_%s.xls'%book_mark
fields_name = 'cinema_movie_%s.xls'%book_mark
wb.save(name)#将数据写入到这个地址的这个xls文件中
return name, fields_name

导出excel,并将数据返回给前端(包含权限判断)的更多相关文章

  1. Java利用POI导入导出Excel中的数据

         首先谈一下今天发生的一件开心的事,本着一颗android的心我被分配到了PB组,身在曹营心在汉啊!好吧,今天要记录和分享的是Java利用POI导入导出Excel中的数据.下面POI包的下载地 ...

  2. php 导出excel 10万数据

    php导出excel 10万数据(此代码主要测试用) 在工作当中要对一些基本信息和其他信息导出 起初信息比较小无所谓.... 但当信息超出65535的时候 发现点问题了 超出了 而且 反应速度很慢 实 ...

  3. C#导入导出Excel表的数据

    一:C#导入导出EXCEL文件的类 代码如下: 首先将Microsoft Excel 14.0 Object Library 引用导入 using System; using System.Data; ...

  4. C#弹出窗体、C#导出Excel、C#数据展示框、C#弹出框

    1.new 一个窗体,然后设置窗体属性. 2.添加数据展示控件,显示数据. 3.添加按钮控件,调用导出Excel代码,实现导出Excel功能. using System; using System.C ...

  5. thinkphp导入导出excel表单数据

    在PHP项目经常要导入导出Excel表单. 先去下载PHPExcel类库文件,放到相应位置. 我在thinkphp框架中的位置为ThinkPHP/Library/Org/Util/ 导入 在页面上传e ...

  6. 使用NPOI导入导出Excel(xls/xlsx)数据到DataTable中

    using System; using System.Collections.Generic; using System.Text; using System.IO; using NPOI.SS.Us ...

  7. poi导出excel,表头数据动态拼装

    /* * 第一步:拼装表头和数据 */ // 放多个sheet的集合 List<Map<String,Object>> datas = new ArrayList<Map ...

  8. winfrom 使用NPOI导入导出Excel(xls/xlsx)数据到DataTable中

    1.通过NUGET管理器下载nopi,在引入命令空间 using System; using System.Collections.Generic; using System.Text; using ...

  9. 关于JavaDate数据返回到前端变数字的问题(并引申到前后端时间的传输)

    不知道为什么,前端显示的所有数据项都没有错,就只有时间那一项很奇怪,是一串数字,而且这个数字在数据库怎么都找不到…… 然后我在后端从service到controller都debug了一遍,发现数据都没 ...

随机推荐

  1. position:fixed 兼容浏览器低版本

    项目中遇到的坑,写篇博客做个笔记纪念下,position: fixed一般来说都兼容各个浏览器,但是要兼容浏览低版本问题,就得用-webkit-transform: translateZ(0);这段代 ...

  2. 解决nim db_mysql could not load: libmysql.dll的问题

    title: 解决nim db_mysql could not load: libmysql.dll的问题 nim中使用db_mysql 操作数据库的代码看起来很简单: import db_mysql ...

  3. oracle 建表默认空间

    oralce 建表后会有默认表空间,如果没有指定表空间会把所有信息放到users表空间内.要改默认空间 ,首先当前用户要有权限,然后按照 alter database 表名 tablespace 表空 ...

  4. python网络编程(UDP+广播)

    UDP广播案例,一端发送,多端接受: 发送端: # UDP广播案例 from socket import * from time import sleep # 设定目标地址 dest=('176.21 ...

  5. 精进之路之HashMap

    HashMap本质的核心就是“数组+链表”,数组对于访问速度很快,而链表的优势在于插入速度快,HashMap集二者于一身. 提到HashMap,我们不得不提各个版本对于HashMap的不同.本文中先从 ...

  6. 使用mbedtls的使用说明和AES加密方法(原来的PolarSSL)

    关于PolarSSL mbed TLS(以前称为PolarSSL)是TLS和SSL协议的实现,并且需要相应的加密算法和支持代码.这是双重许可与Apache许可证 2.0版(与GPLv2许可也可).网站 ...

  7. MySql5.7多实例配置教程

    最近朋友在搞在Linux上配置MySql5.7多实例教程,在网上查询了很多资料,一直报各种各样的错误,后来在网上搜了一篇博客,根据其配置,最近是配置成功了 参考配置连接:https://blog.cs ...

  8. mknod语法

    1.语法       mknod [选项]  设备名  设备类型  主设备号 次设备号   2.选项参数列表 选项 说明 --version 显示命令版本信息 --help 显示帮助信息 -m | - ...

  9. yamux多路复用的使用例子

    yamux yamux 是一个多路复用库.它依赖于底层可靠有序连接.如TCP. 提供基于流的多路利用 例子如下: Server package main // 多路复用 import ( " ...

  10. pagerank 数学基础

    网页排序的任务中,最核心的难点在于判别网页质量. 将互联网上的网页模拟为一个节点,而这个网页的“出链”看做是指向其他节点的一条“有向边”,而“入链”则是其他节点指向这个节点的有向边.这样整个网络就变成 ...