Python 使用一对多关系在Django中创建两种不同的用户类型

Python 使用一对多关系在Django中创建两种不同的用户类型,python,django,Python,Django,我正在创建一个篮球统计应用程序,我希望有两种不同的用户类型,教练和球员。我希望教练能够登录并只查看球员的数据。因此,一名教练将有许多球员。我希望能够为每个教练创建用户配置文件,只显示他们的球员,而不是数据库中的所有球员。到目前为止,我已经创建了显示所有注册用户的用户配置文件,但我不知道如何将这两个用户分开,以便让球员在教练的指导下。另外,如何以HTML格式显示教练下列出的所有球员?谢谢你 Models.py视图: from django.db import models from django.

我正在创建一个篮球统计应用程序,我希望有两种不同的用户类型,教练和球员。我希望教练能够登录并只查看球员的数据。因此,一名教练将有许多球员。我希望能够为每个教练创建用户配置文件,只显示他们的球员,而不是数据库中的所有球员。到目前为止,我已经创建了显示所有注册用户的用户配置文件,但我不知道如何将这两个用户分开,以便让球员在教练的指导下。另外,如何以HTML格式显示教练下列出的所有球员?谢谢你

Models.py视图:

from django.db import models
from django.contrib.auth.models import User
from django.db.models.signals import post_save


class UserProfile(models.Model):
name = models.CharField(max_length=100, default='')
school_name = models.CharField(max_length=100, default='')
user = models.OneToOneField(User, on_delete=models.CASCADE)
description = models.CharField(max_length=100, default='')
city = models.CharField(max_length=100, default='')
state = models.CharField(max_length=100, default='')
website = models.URLField(default='')
phone = models.IntegerField(default=0)
jersey_number = models.IntegerField(default=0)
image = models.ImageField(upload_to='profile_image', blank=True)
position = models.CharField(max_length=100, default='')
height = models.CharField(max_length=100, default='')
weight = models.CharField(max_length=100, default='')
grade = models.CharField(max_length=100, default='')
background_image = models.ImageField(upload_to='profile_image', blank=True)

def __str__(self):
    return self.user.username


def create_profile(sender, **kwargs):
if kwargs['created']:
    user_profile = UserProfile.objects.create(user=kwargs['instance'])

post_save.connect(create_profile, sender=User)
Views.py:

@login_required(login_url='login')
def view_profile(request, pk=None):
if pk:
    user = User.objects.get(pk=pk)
else:
    user = request.user
args = {'user': user}
return render(request, 'accounts/profile.html', args)
因此,我以用户身份登录,它显示两个玩家。我希望它只显示player1,然后作为另一个教练登录,它显示player2

[![在此处输入图像描述][1][1]

Django管理视图: 因此,如果我在每个用户下登录,它将显示所有用户。例如:我想在1个用户(教练)下登录并显示球员1-4,然后在另一个教练下登录,并显示球员5-7。 [![在此处输入图像描述][2][2]

HTML视图:

<div class="column middle">
                <table id="roster" class="table table-bordered table-hover table-condensed"><!--add roster-->
                    <h2>Roster</h2>
                    <thead>
                        <tr>
                            <th scope="col">#</th>
                            <th scope="col">Player Name</th>
                            <th scope="col">Position</th>
                            <th scope="col">Grade</th>
                        </tr>
                    </thead>
                    <tbody>
                                {% for user in users %}
                        <tr>
                            <td class="number">{{ user.userprofile.jersey_number }} </td>
                            <td class="name">
                                {% if user.userprofile.image %}
                                <img src="{{ user.userprofile.image.url }}" width="60" height="75" vspace="10">
                                {% endif %}
                                <a href="{% url 'view_profile_with_pk' pk=user.pk %}">
                                {{ user.userprofile.name }}
                                </a>
                            </td>
                            <td class="position">{{ user.userprofile.position }}</td>
                            <td class="grade">{{ user.userprofile.grade }}</td>
                        </tr>
                                {% endfor %}

                    </tbody>
                </table>
            </div>

名册
#
球员姓名
位置
等级
{users%%中的用户为%s}
{{user.userprofile.jersey_number}
{%if user.userprofile.image%}
{%endif%}
{{user.userprofile.position}
{{user.userprofile.grade}
{%endfor%}

不要对教练和球员使用相同的模式,而是将他们分开。您还可以创建一个团队的抽象概念,这是一个好主意,因为您可能希望每个团队都有多个教练,或者让教练在一年内指导一个团队,在下一年指导另一个团队

models.py

class Coach(models.Model):
    user = models.OneToOneField("auth.User")
    # ... Other info

class Team(models.Model):
     coach = models.OneToOneField(Coach)
     # ... Other info

class Player(models.Model):
     user = models.OneToOneField("auth.User")
     team = models.ForeignKey(Team)
     # ... Other info
如果你想要一名球员教练:

player = Player.objects.get(...)
players_coach = player.team.coach
或者,如果您想获得一名教练或球员:

coach = Coach.objects.get(...)
coaches_players = coach.team.player_set.all()
这还允许您轻松更改教练和球员之间的关系,如将教练和球队之间的外键更改为ManyToManyField,以便允许每个球队有多个教练,并且教练可以多年来指导多个球队

-------------下面是您可以如何实现它----------------

然后在HTML模板中:

{% for player in coaches_players %}
<p>{{ player }}</p>
{% endfor %}
{教练中球员的百分比\球员%}
{{player}}

{%endfor%}
“谢谢您提供的信息。我可以在django管理员中添加Coach、Player和Team用户。您能帮我澄清一下答案的第二部分吗?我应该将“Player=Player.objects.get(…)Player\u Coach=Player.Team.Coach”放在哪里" ? 在views.py下?我应该使用与上面所述相同的view_profile函数并合并您的信息,还是应该定义一个新函数?我正在尝试让它工作,现在我可以在登录时查看教练1的名册。“我应该如何在views.py页面上编写函数?你也能帮忙吗?谢谢。我很乐意帮助你。然而,问题最后一部分的位置完全取决于你的应用程序。这只是一个简单的实现,所以无论您需要在哪里检索球员和教练,都需要在哪里放置相应的查询。根据您提供的视图,我将尝试在我的答案中显示更新的位置。将玩家列表添加到上下文,将上下文发送到模板,然后循环它们。看我的最新答案没问题。下面是如何在HTML中循环它们:{%forplayer in coaches_players%}{{player}

{%endfor%}
{% for player in coaches_players %}
<p>{{ player }}</p>
{% endfor %}