1

クエリセットで複数のモデルを使用できる方法を見つけようとしています。たとえば、私の場合、写真とユーザーの 2 つのテーブルがあります。

class Photo(models.Model):
username = models.ForeignKey(User)
image = models.ImageField(upload_to='photos')
alt_text = models.CharField(max_length=255)

class DR_User(models.Model):
    userid = models.ForeignKey(User)
    follows = models.ManyToManyField('self', related_name='followed_by', symmetrical=False, blank=True)
objects = DR_User_Manager()

class DR_User_Query_Set(QuerySet):
    def profile_pic(self):
        # uid = self.userid
        photo = Photo.objects.get(username=uid)
        if photo.exists():
            return photo.image.url
        else:
            return 'http://d12df125d01b8a258a3a-8112fdc02f7d385b44f56eb9e899d81c.r88.cf2.rackcdn.com/default.png'

    def userinfo(self):
        uid = self.userid
        obj = User.objects.get(id=uid)
        userinfo = obj.first_name + ' ' + obj.last_name
        return userinfo.title()

class DR_User_Manager(models.Manager):
    def get_query_set(self):
        return DR_User_Query_Set(self.model)
    def __getattr__(self, name):
        return getattr(self.get_query_set(), name)

私の目的は、ユーザーテーブル(auth_user)からユーザー情報を取得し、写真テーブルから画像のURLを取得できるDR_Userのカスタムクエリセットを作成することです...使用すると-

user = DR_user.objects.all()

テンプレートで {{ user.profile_pic }} と {{ user.userinfo }} を使用して一度にアクセスできます。

4

1 に答える 1

0

働き過ぎ。

class DR_User(models.Model):
   ...
  @property
  def profile_pic(self):
    try:
      return self.userid.image.url
    except models.DoesNotExist:
      return settings.DEFAULT_PROFILE_PIC_URL

  @property
  def userinfo(self):
    return unicode(self.userid)
于 2013-07-22T05:27:06.747 に答える