如何解决如何在 Django 日历中按当前用户对事件进行排序
我在 Django 日历中对事件进行排序时遇到问题,即,我想不仅按日期过滤它们,还想按创建事件的用户过滤它们,以便只有他的事件显示在日历上,而不显示其他用户
这是我的 utils.py 文件
class Calendar(LocaleHTMLCalendar):
def __init__(self,year=None,month=None):
self.year = year
self.month = month
super(Calendar,self).__init__()
# formats a day as a td
# filter events by day
def formatday(self,day,events):
events_per_day = events.filter(start_time__day=day)
d = ''
for event in events_per_day:
d += f'<li> {event.get_html_url} </li>'
if day != 0:
return f"<td><span class='date'>{day}</span><ul> {d} </ul></td>"
return '<td></td>'
# formats a week as a tr
def formatweek(self,theweek,events):
week = ''
for d,weekday in theweek:
week += self.formatday(d,events)
print()
return f'<tr> {week} </tr>'
# formats a month as a table
# filter events by year and month
def formatmonth(self,withyear=True,):
events = Event.objects.filter(start_time__year=self.year,start_time__month=self.month,)
cal = f'<table border="0" cellpadding="0" cellspacing="0" class="calendar">\n'
cal += f'{self.formatmonthname(self.year,self.month,withyear=withyear)}\n'
cal += f'{self.formatweekheader()}\n'
for week in self.monthdays2calendar(self.year,self.month):
cal += f'{self.formatweek(week,events)}\n'
return cal
我的问题是我不知道如何对对象中的当前用户应用过滤,因为我无法导入 request.user
这是我的models.py文件
user = models.ForeignKey(User,on_delete=models.CASCADE)
start_time = models.DateTimeField(auto_Now_add=False,auto_Now=False,auto_created=False)
end_time = models.DateTimeField(auto_Now_add=False,auto_created=False)
def __str__(self):
return str(self.user)
def get_absolute_url(self):
return reverse('sytoapp:event-detail',args=(self.id,))
@property
def get_html_url(self):
url = reverse('sytoapp:event-detail',))
return f'<a href="{url}"> {self.user} </a>'
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。