双下划线, 表示该对象的属性
class UserCourse(models.Model):
# 用户选择的课程
user = models.ForeignKey(UserProfile, verbose_name=u"UserObject", on_delete=models.CASCADE)
course = models.ForeignKey(Course, verbose_name=u"Course", on_delete=models.CASCADE)
add_time = models.DateTimeField(default=datetime.now, verbose_name=u"Added Time")
class Meta:
verbose_name = u"User's Courses"
verbose_name_plural = verbose_name
#--------------------------------------------------------------#
#需求;根据一个课程找到 选择了这个课程的同学们 还选择了哪些课程
#根据课程对象拿到一个列表 (选择了这门课的用户ID列表)
user_courses = UserCourse.objects.filter(course=course)
#神奇的语法, 先写for 再in 最后 写第一个参数
user_ids = [user_course_item.user.id for user_course_item in user_courses]
# 更神奇的 __in 双下划线in (遍历这些用户都选择了哪些课)
all_user_courses = UserCourse.objects.filter(user_id__in=user_ids).distinct()
relate_courses = Course.objects.filter(id__in=all_user_courses.course.id)
关键词搜索
searched_course = all_course.filter(name__icontains=search_keywords)
或查询
from django.db.models import Q
#__contains 区分大小写 __icontains 不区分大小写
searched_course = all_course.filter(Q(name__icontains=search_keywords)|Q(desc__icontains=searche_keywords))
enumerate() 函数
使用 enumerate() 函数,我们可以在for循环中同时绑定索引index和元素name。但是,这不是 enumerate() 的特殊语法。实际上,enumerate() 函数把:
['Adam', 'Lisa', 'Bart', 'Paul']
变成了类似:
[(0, 'Adam'), (1, 'Lisa'), (2, 'Bart'), (3, 'Paul')]
# 简化写法
for index, name in enumerate(L):
print index, '-', name
for循环
列表生成式
>>> [x * x for x in range(1, 11)]
[1, 4, 9, 16, 25, 36, 49, 64, 81, 100]
这种写法就是Python特有的列表生成式。利用列表生成式,可以以非常简洁的代码生成 list
列表生成式的 for 循环后面还可以加上 if 判断。例如:
>>> [x * x for x in range(1, 11)]
[1, 4, 9, 16, 25, 36, 49, 64, 81, 100]
如果我们只想要偶数的平方,不改动 range()的情况下,可以加上 if 来筛选:
>>> [x * x for x in range(1, 11) if x % 2 == 0]
[4, 16, 36, 64, 100]
有了 if 条件,只有 if 判断为 True 的时候,才把循环的当前元素添加到列表中。
多层for
for循环可以嵌套,因此,在列表生成式中,也可以用多层 for 循环来生成列表。
对于字符串 'ABC' 和 '123',可以使用两层循环,生成全排列:
>>> [m + n for m in 'ABC' for n in '123']
['A1', 'A2', 'A3', 'B1', 'B2', 'B3', 'C1', 'C2', 'C3']
翻译成循环代码就像下面这样:
L = []
for m in 'ABC':
for n in '123':
L.append(m + n)