python 实现从excel表中读取数据并存入class()类以实现数据关联

首先打开现有的表格
初始人员信息库:姓名、房间号、床号

import xlrd
#打开人员信息表
wb1=xlrd.open_workbook("C:\\Users\\Bruce Shaw\\Desktop\\datap.xls")#括号里为路径
sheet1=wb1.sheet_by_index(0)#索引至页
#创建类,读入人员信息:序号、姓名、房间号、床号
class P():
    def __init__(self, num=0, name="name", room=0, bed=0):
        self.num = num
        self.name = name
        self.room = room
        self. bed =  bed
n=int(input("请输入总人数:"))+1 #输入值班的人数,n为值班人数加1
Sentry= [] # 创建列表,以将类通过append加入其中,避免覆盖
for i in range(1,n):
    Sentry.append(P())
#中间量,以暂时存储从表中读取的数据
Name=[]
Room=[]
Bed=[]
for i in range(1,n): 
    Name.append(sheet1.cell_value(i,1))
    Room.append(sheet1.cell_value(i,2))
    Bed.a
  • 4
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在 Django ,使用 ModelForm 可以方便地将模型数据映射到单上,并且可以通过单来对模型的数据进行增删改查等操作。如果需要在网页上上传多个文件并将文件内容保存到数据,可以使用 Django 的 MultiValueDict 来实现。 下面是一个示例代码,演示了如何使用 ModelForm 和 MultiValueDict 来实现多文件上传,并将文件内容保存到数据: ```python # models.py from django.db import models class File(models.Model): name = models.CharField(max_length=255) content = models.TextField() # forms.py from django import forms from django.forms import inlineformset_factory from .models import File class FileForm(forms.ModelForm): class Meta: model = File fields = ('name',) class ContentForm(forms.ModelForm): class Meta: model = File fields = ('content',) ContentFormSet = inlineformset_factory(File, File, form=ContentForm, extra=1) # views.py from django.shortcuts import render from django.utils.datastructures import MultiValueDictKeyError from .forms import FileForm, ContentFormSet def upload(request): if request.method == 'POST': form = FileForm(request.POST, request.FILES) content_formset = ContentFormSet(request.POST, request.FILES, instance=File()) if form.is_valid() and content_formset.is_valid(): file = form.save() for content_form in content_formset: try: content = content_form.cleaned_data['content'] file.content = content.read() file.save() except MultiValueDictKeyError: pass else: form = FileForm() content_formset = ContentFormSet(instance=File()) return render(request, 'upload.html', {'form': form, 'content_formset': content_formset}) ``` 在上述代码,首先定义了一个模型 `File`,其包含了两个字段 `name` 和 `content`,分别用于保存文件名和文件内容。然后定义了两个单 `FileForm` 和 `ContentForm`,其 `FileForm` 用于上传文件名,`ContentForm` 用于上传文件内容。同时使用 `inlineformset_factory` 创建了一个 `ContentFormSet`,用于在网页上动态添加多个 `ContentForm` 单。 在视图函数 `upload` ,首先判断请求的方法是否为 POST,如果是,则创建两个单实例,并分别对它们进行校验。如果数据有效,则先保存 `FileForm` 数据,然后遍历 `ContentFormSet` 的所有数据,将每个上传的文件的内容读取出来,并保存到数据。最后将单渲染到网页上。 需要注意的是,为了在上传文件时能够正确地读取文件内容,需要将单的 `enctype` 设置为 `multipart/form-data`,并且在视图函数使用 `request.FILES` 来获取上传的文件数据。 希望这个示例可以帮助你实现多文件上传并保存到数据。如果还有其他问题,可以继续提问哦~
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值