欢迎光临
我们一直在努力

程序员超过最大递归深度,保存方法,Django – python

程序员面试经验

尝试使用Python3.4使用QR代码5.3生成QR代码时。我面临几个问题:

最初,我使用io.StringIO并获得了预期的字符串参数,并收到了“字节”错误消息。因此,然后将io.StringIO更改为io.BytesIO。然后我得到另一个错误,它是“ _io.BytesIO”对象没有属性“ len”,因此为了获得使用的对象的长度buffer.getbuffer()。nbytes,但是现在我得到的最大递归深度超过了它会生成298个QR码图像,而不仅仅是一个。有什么想法我做错了吗?

from django.db import models from django.conf import settings from django.core.urlresolvers import reverse from django.core.files.uploadedfile import InMemoryUploadedFile  import random import qrcode import io import sys  from PIL import Image  import pdb;   def qrcode_location(instance, filename):     return '%s/qr_codes/%s' % (instance.user.username, filename)   # Create your models here. class EmployeeProfile(models.Model):     user = models.ForeignKey(settings.AUTH_USER_MODEL,  on_delete=models.CASCADE)     qrcode = models.ImageField(upload_to=qrcode_location, null=True, blank=True)     first_name = models.CharField(max_length=30)     last_name = models.CharField(max_length=30)      def __str__(self):         return self.first_name + ' ' + self.lastname      def save(self):         first_initial = self.first_name[0].upper()         second_initial = self.last_name[0].upper()         id_number = first_initial + second_initial + str(random.randint(1000000, 9999999))         self.generate_qrcode()          if not EmployeeProfile.objects.filter(employee_id=id_number).exists():             self.employee_id = id_number             super(EmployeeProfile, self).save()      def generate_qrcode(self):         qr = qrcode.QRCode(             version=1,             error_correction=qrcode.constants.ERROR_CORRECT_L,             box_size=10,             border=4,         )         qr.add_data('Some data')         qr.make(fit=True)          img = qr.make_image()          buffer = io.BytesIO()         img.save(buffer)         filename = 'qrcode.png'         filebuffer = InMemoryUploadedFile(buffer, None, filename, 'image/png', buffer.getbuffer().nbytes, None)         self.qrcode.save(filename, filebuffer) 

——————–解决方案更新—————————- —

由于保存调用了generate_qrcode,而调用了self.qrcode.save,并且模型调用了save导致无限递归。因此,为防止出现这种情况,您只需为FileField的save方法提供一个附加的第三个参数来绕过它。

Django FileField in model maximum recursion depth exceeded while calling a Python object

# set 3 argument to false(save=False) otherwise infinite recursion will happen self.qrcode.save(filename, filebuffer, False) 

参考方案

self.qrcode.save表示需要保存整个模型对象,因此会导致调用save并调用generate_qrcode调用self.qrcode.save …(通过这种方式,您应该能够在回溯),因此您的问题与BytesIO无关。在某个地方插入一个条件以打破递归循环。

Python GPU资源利用 – python

我有一个Python脚本在某些深度学习模型上运行推理。有什么办法可以找出GPU资源的利用率水平?例如,使用着色器,float16乘法器等。我似乎在网上找不到太多有关这些GPU资源的文档。谢谢! 参考方案 您可以尝试在像Renderdoc这样的GPU分析器中运行pyxthon应用程序。它将分析您的跑步情况。您将能够获得有关已使用资源,已用缓冲区,不同渲染状态上…

Python sqlite3数据库已锁定 – python

我在Windows上使用Python 3和sqlite3。我正在开发一个使用数据库存储联系人的小型应用程序。我注意到,如果应用程序被强制关闭(通过错误或通过任务管理器结束),则会收到sqlite3错误(sqlite3.OperationalError:数据库已锁定)。我想这是因为在应用程序关闭之前,我没有正确关闭数据库连接。我已经试过了: connectio…

python:ConfigParser对象,然后再阅读一次 – python

场景:我有一个配置文件,其中包含要执行的自动化测试的列表。这些测试是长期循环执行的。   配置文件的设计方式使ConfigParser可以读取它。由于有两个三个参数,因此我需要通过每个测试。现在,此配置文件由script(s1)调用,并且按照配置文件中的列表执行测试。Script(s1)第一次读取配置,并且在每次测试完成后都会执行。阅读两次的要求:由于可能会…

Python exchangelib在子文件夹中读取邮件 – python

我想从Outlook邮箱的子文件夹中读取邮件。Inbox ├──myfolder 我可以使用account.inbox.all()阅读收件箱,但我想阅读myfolder中的邮件我尝试了此页面folder部分中的内容,但无法正确完成https://pypi.python.org/pypi/exchangelib/ 参考方案 您需要首先掌握Folder的myfo…

python-docx应该在空单元格已满时返回空单元格 – python

我试图遍历文档中的所有表并从中提取文本。作为中间步骤,我只是尝试将文本打印到控制台。我在类似的帖子中已经看过scanny提供的其他代码,但是由于某种原因,它并没有提供我正在解析的文档的预期输出可以在https://www.ontario.ca/laws/regulation/140300中找到该文档from docx import Document from…

赞(0)
未经允许不得转载: 京大飞辅助网程序员面试-区块链javago面经 » 程序员超过最大递归深度,保存方法,Django – python

相关推荐

评论 抢沙发

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址