How to declare a auto-incrementing alphanumerical id field with predefined aplphabetic part (Django python)

早过忘川 提交于 2020-04-17 22:51:28

问题


I am developing an app in Django.

I want to insert in my model an auto-incrementing alphanumerical ID field, having, by default, a fixed alphabetical part and an auto-incrementing numerical part. But I also want the availability to change, from admin section, this id to another alphanumerical one, with a different alphanumerical and numerical part. Please note: I don't want to overwrite the django default id field, I just want to include in my model a field that gets as default value an auto-incrementing alphanumerical value.

Example:

Desired alphabetical constant part: ITM

Desired numerical auto-incrementing part: 00000

So that every object of my model, when generated, get default progressive values like: ITM00001, ITM00002, ITM00003, ...

I would like to change the field value from my admin section into, for example: ABC0000001, DFG0051, RST034, ...

Max field length: 10 (It can be also higher)

I realize that I have to use AutoField and to somehow join the constant string with the auto-incrementing numerical variable, but I don't know how to do it.

class my_model(models.Model):

    Field_1 = models.CharField(max_length=10, blank=True, null=True)
    static_ID = models.AutoField(???)

回答1:


Maybe you can split your field into three separate fields:

class MyModel(models.Model):
    PREF = "ITM"
    NUMS = 5

    field1 = models.CharField(max_length=10, blank=True, null=True)
    ...
    pref = models.CharField(max_length=3, default=PREF)  # prefix that has defaul value and can be modified
    nums = models.PositiveIntegerField(default=NUMS)  # the number of digits
    static_id = models.AutoField(primary_key=False)  # auto increment field

    class Meta:
        unique_together = ('pref', 'nums', 'static_id')

    @property
    def static_key(self):
        return self.pref + str(self.static_id).zfill(self.nums)



回答2:


Instead of storing it, why not use a property method to generate that id? For example:

class MyModel(models.Model):

    field_one = models.CharField(max_length=10, blank=True, null=True)

    @property
    def static_id(self):
        'ITM{0:07d}'.format(self.pk)

If you are concerned with filtering, then you can use custom manager method:

class CustomManager(models.Manager):
    def get_id(self, static_id):
        return int(static_id[2:])
    def filter_static_id(self, static_id):
        _id = self.get_id(static_id)
        return self.filter(pk=_id)

  def filter_static_id(self, static_id):
        _id = self.get_id(static_id)
        return self.get(pk=_id)

 class MyModel(models.Model):
      objects = CustomManager()



回答3:


SOLVED:

Since I don't need a specific length for my id, nor a constant increment between two consecutive ids, I can use time.time() to get a unique time number every time the object in the model is created. Then I can turn that time number into a string and concatenate it with a constant prefix.

In models.py:

import time

def return_timestamped_id():
    prefix = "ITCH"     
    timestamp = str(int(time.time()*10000000))
    default_value = prefix + timestamp
    return(default_value)


class my_model(models.Model):        
    Field_1 = models.CharField(max_length=256)
    static_ID = models.CharField(max_length=256, blank=False, null=False, default=return_timestamped_id)


来源:https://stackoverflow.com/questions/60113117/how-to-declare-a-auto-incrementing-alphanumerical-id-field-with-predefined-aplph

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!