程序员最近都爱上了这个网站  程序员们快来瞅瞅吧!  it98k网:it98k.com

本站消息

站长简介/公众号

  出租广告位,需要合作请联系站长

+关注
已关注

分类  

暂无分类

标签  

暂无标签

日期归档  

Python遍历技巧

发布于2019-08-07 14:55     阅读(425)     评论(0)     点赞(2)     收藏(5)


双下划线, 表示该对象的属性

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)
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23

关键词搜索

searched_course = all_course.filter(name__icontains=search_keywords)
  • 1

或查询

from django.db.models import Q
#__contains 区分大小写  __icontains 不区分大小写
searched_course = all_course.filter(Q(name__icontains=search_keywords)|Q(desc__icontains=searche_keywords))
  • 1
  • 2
  • 3

enumerate() 函数

使用 enumerate() 函数,我们可以在for循环中同时绑定索引index和元素name。但是,这不是 enumerate() 的特殊语法。实际上,enumerate() 函数把:

['Adam', 'Lisa', 'Bart', 'Paul']
  • 1

变成了类似:

[(0, 'Adam'), (1, 'Lisa'), (2, 'Bart'), (3, 'Paul')]
# 简化写法
for index, name in enumerate(L):
    print index, '-', name
  • 1
  • 2
  • 3
  • 4

for循环

列表生成式

>>> [x * x for x in range(1, 11)]
[1, 4, 9, 16, 25, 36, 49, 64, 81, 100]
这种写法就是Python特有的列表生成式。利用列表生成式,可以以非常简洁的代码生成 list
  • 1
  • 2
  • 3

列表生成式的 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 的时候,才把循环的当前元素添加到列表中。
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7

多层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)
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12


所属网站分类: 技术文章 > 博客

作者:爸爸去挣钱我去幼儿园

链接:https://www.pythonheidong.com/blog/article/11407/84fbdec18a4b7b33ae22/

来源:python黑洞网

任何形式的转载都请注明出处,如有侵权 一经发现 必将追究其法律责任

2 0
收藏该文
已收藏

评论内容:(最多支持255个字符)