Django上传Excel或word读取内容并入库

Excel

#1. model 层
class Monitoring(models.Model):
    id = models.AutoField(primary_key=True,verbose_name="talentId")
    name = models.CharField(max_length=15, verbose_name="用户名称",null=True)
    workUnit = models.CharField(max_length=15, verbose_name="工作单位",null=True)
    professional = models.CharField(max_length=15, verbose_name="专业领域",null=True)
    storagetime = models.CharField(max_length=15, verbose_name="入库时间", null=True)


    class Meta:
        managed = True
        db_table = 'monitoring'

import xlrd
from django.utils import timezone
class upLoad(View):

    def post(self,request):
        f = request.FILES.get('file').read()
        wb = xlrd.open_workbook(filename=None,file_contents=f)
        table = wb.sheets()[0]
        row = table.nrows
        data_list=[]
        for i in range(1,row):
            col = table.row_values(i)
            datetime1 = timezone.now().strftime("%Y-%m-%d %H:%M:%S")
            data_list.append(Monitoring(name=col[0],workUnit=col[1],professional=col[2],storagetime=datetime1))
        Monitoring.objects.bulk_create(data_list)
        json_data = serializers.serialize('json',data_list)
        json_data = json.loads(json_data)
        json_data1 = [] # 返回上传的信息
        for i in json_data:
            json_data1.append(i['fields'])
        return JsonResponse({"coed":'200','data':json_data1})

Word

#1. model 层

class wordAddress(models.Model):
    word_id = models.AutoField(primary_key=True)
    word_path = models.CharField(max_length=500)

#2. view 层
import io
import docx
upload_file = request.FILES['file'].read()
    doc = docx.Document(io.BytesIO(upload_file))
    print(doc)
    # file = docx.Document("F:\\ocr\\image_json\\xxx.docx")
    for para in doc.paragraphs:
        print(para.text)
        wordAddress1 = wordAddress(word_path=para.text)
        wordAddress1.save()
    return HttpResponse('success')
  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
可以使用Django自带的`FileField`来接收上传excel文件,并保存在本地。具体步骤如下: 1. 在Django的Model中定义一个包含`FileField`的Model,用于保存上传excel文件。 ```python from django.db import models class Excel(models.Model): file = models.FileField(upload_to='excel/') ``` `upload_to`参数指定文件上传后保存的目录,这里设置为`excel/`目录。 2. 在前端页面中添加一个文件上传的表单,以便用户上传excel文件。 ```html <form action="{% url 'upload_excel' %}" method="post" enctype="multipart/form-data"> {% csrf_token %} <input type="file" name="file"> <button type="submit">上传</button> </form> ``` 3. 在Django的视图函数中处理上传excel文件,将其保存在本地。 ```python import os from django.conf import settings from django.shortcuts import render from django.http import HttpResponse from .models import Excel def upload_excel(request): if request.method == 'POST': file = request.FILES.get('file') if file: filename = file.name path = os.path.join(settings.MEDIA_ROOT, 'excel', filename) with open(path, 'wb') as f: for chunk in file.chunks(): f.write(chunk) Excel.objects.create(file=os.path.join('excel', filename)) return HttpResponse('上传成功') return render(request, 'upload.html') ``` 在视图函数中,首先从`request.FILES`中获取上传excel文件,然后将文件保存在指定目录下,并创建一个Excel对象,将文件路径保存到数据库中。 4. 最后,需要在`settings.py`中配置上传文件的存储路径。 ```python MEDIA_URL = '/media/' MEDIA_ROOT = os.path.join(BASE_DIR, 'media') ``` 以上就是Django接收前端上传excel文件,并保存在本地的完整流程。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值