django多条件筛选搜索(项目实例)

多条件搜索在很多网站上都有用到,比如京东,淘宝,51cto,等等好多购物教育网站上都有,当然网上也有很多开源的比楼主写的好的多了去了,仅供参考,哈哈

先来一张效果图吧,不然幻想不出来是什么样的,前端样式很low,毕竟主要是说后台的嘛,前端为了简单测试就简单的写出来啦,喜欢好的样式可以自己去调哈

写后台的应该都知道先从数据库方面入手,所以我们先来设计数据库

数据库设计

1、视频video

class Video(models.Model):

    status_choice = (
        (0, u‘下线‘),
        (1, u‘上线‘),
    )
    level_choice = (
        (1, u‘初级‘),
        (2, u‘中级‘),
        (3, u‘高级‘),
    )
    status = models.IntegerField(verbose_name=‘状态‘, choices=status_choice, default=1)
    level = models.IntegerField(verbose_name=‘级别‘, choices=level_choice, default=1)
    classification = models.ForeignKey(‘Classification‘, null=True, blank=True)

    weight = models.IntegerField(verbose_name=‘权重(按从大到小排列)‘, default=0)

    title = models.CharField(verbose_name=‘标题‘, max_length=32)
    summary = models.CharField(verbose_name=‘简介‘, max_length=32)
    img = models.ImageField(verbose_name=‘图片‘, upload_to=‘./static/images/Video/‘)
    href = models.CharField(verbose_name=‘视频地址‘, max_length=256)

    create_date = models.DateTimeField(auto_now_add=True)

    class Meta:
        db_table = ‘Video‘
        verbose_name_plural = u‘视频‘

    def __str__(self):
        return self.title

2、视频方向Direction

class Direction(models.Model):
    weight = models.IntegerField(verbose_name=‘权重(按从大到小排列)‘, default=0)
    name = models.CharField(verbose_name=‘名称‘, max_length=32)

    classification = models.ManyToManyField(‘Classification‘)

    class Meta:
        db_table = ‘Direction‘
        verbose_name_plural = u‘方向(视频方向)‘

    def __str__(self):
        return self.name

3、视频分类Classification

class Classification(models.Model):
    weight = models.IntegerField(verbose_name=‘权重(按从大到小排列)‘, default=0)
    name = models.CharField(verbose_name=‘名称‘, max_length=32)

    class Meta:
        db_table = ‘Classification‘
        verbose_name_plural = u‘分类(视频分类)‘

    def __str__(self):
        return self.name

好了大家一起来分析下数据库设计

  • 视频方向Direction类和视频分类Classification多对多关系,因为一个视频方向可以有多个分类,一个视频分类也可以有多个视频方向视频分类
  • Classification视频分类和视频Video类是一对多关系,因为一个分类肯定有好多视频
  • 视频Video类中level_choice 与视频也是一对多关系,因为这个也就这三个分类,所以我选择把他放在内存里面取,毕竟这玩意常年不会变

url映射

from django.conf.urls import url
from django.contrib import admin
from app01 import views
urlpatterns = [
    url(r‘^admin/‘, admin.site.urls),
    url(r‘^video-(?P<direction_id>\d+)-(?P<classification_id>\d+)-(?P<level_id>\d+).html‘, views.video),
]

输入的url为:http://127.0.0.1:8080/video-0-0-0.html

  • 中间第一个0代表视频方向,第二个0代表食品分类,第三个0是视频等级,这个是根据汽车之间那个二手车学的,用着很方便哈哈
  • 0代表全部,然后递增,当选择运维自动化,第一个0就会变成1
  • 下面那些都是一样的道理

前端代码

前端HTML,有用到django的simple_tag,从总体效果图可以看出,前端主要分为两部分,选择部分和视频展示部分

1、选择部分

    <h3>选择:</h3>
    <div>
        {% action_all current_url 1 %} :
        {% for item in direction_list %}

             {% action current_url item %}
        {% endfor %}
    </div>
    <div>
        {% action_all current_url 2 %} :
        {% for item in class_list %}

            {% action current_url item %}
        {% endfor %}
    </div>
    <div>
        {% action_all current_url 3 %} :
        {% for item in level_list %}
            {% action current_url item %}
        {% endfor %}
    </div>

中间主要是用simple_tag来做的前端代码

@register.simple_tag
def action_all(current_url,index):
    """
    获取当前url,video-1-1-2.html
    :param current_url:
    :param item:
    :return:
    """
    url_part_list = current_url.split(‘-‘)
    if index == 3:
        if url_part_list[index] == "0.html":
            temp = "<a href=‘%s‘ class=‘active‘>全部</a>"
        else:
            temp = "<a href=‘%s‘>全部</a>"

        url_part_list[index] = "0.html"
    else:
        if url_part_list[index] == "0":
            temp = "<a href=‘%s‘ class=‘active‘>全部</a>"
        else:
            temp = "<a href=‘%s‘>全部</a>"

        url_part_list[index] = "0"

    href = ‘-‘.join(url_part_list)

    temp = temp % (href,)
    return mark_safe(temp)

@register.simple_tag
def action(current_url, item,index):
    # videos-0-0-1.html
    # item: id name
    # video-   2   -0-0.html
    url_part_list = current_url.split(‘-‘)

    if index == 3:
        if str(item[‘id‘]) == url_part_list[3].split(‘.‘)[0]:  #如果当前标签被选中
             temp = "<a href=‘%s‘ class=‘active‘>%s</a>"
        else:
            temp = "<a href=‘%s‘>%s</a>"

        url_part_list[index] = str(item[‘id‘]) + ‘.html‘ #拼接对应位置的部分url
    else:
        if str(item[‘id‘]) == url_part_list[index]:
            temp = "<a href=‘%s‘ class=‘active‘>%s</a>"
        else:
            temp = "<a href=‘%s‘>%s</a>"

        url_part_list[index] = str(item[‘id‘])

    ur_str = ‘-‘.join(url_part_list)  #拼接整体url
    temp = temp %(ur_str, item[‘name‘]) #生成对应的a标签
    return mark_safe(temp)  #返回安全的html

2、视频展示区域

    <h3>视频:</h3>
    {% for item in video_list %}
        <a class="item" href="{{ item.href }}">
            <img src="/{{ item.img }}" width="300px" height="400px">
            <p>{{ item.title }}</p>
            <p>{{ item.summary }}</p>
        </a>
    {% endfor %}

关键来啦关键来啦,最主要的处理部分在这里,往这看,往这看,往这看,主要的事情说三遍哈

视频后台逻辑处理部分

def video(request,*args,**kwargs):
    print(kwargs)
    # 当前请求的路径
    request_path = request.path
    # 从数据库获取视频时的filter条件字典
    q = {}
    # 状态为审核通过的
    q[‘status‘] = 1
    # 获取url中的视频分类id
    class_id = int(kwargs.get(‘classification_id‘))
    # 从数据库中获取所有的视频方向(包括视频方向的id和name)
    direction_list = models.Direction.objects.all().values(‘id‘,‘name‘)

    # 如果视频方向是0
    if kwargs.get(‘direction_id‘) == ‘0‘:
        # 方向选择全部
        # 方向id=0,即获取所有的视频分类(包括视频分类的id和name)
        class_list = models.Classification.objects.all().values(‘id‘, ‘name‘)
        # 如果视频分类id也为0,即全部分类,那就什么都不用做,因为已经全取出来了
        if kwargs.get(‘classification_id‘) == ‘0‘:
            pass
        else:
            # 如果视频分类不是全部,过滤条件为视频分类id在[url中的视频分类id]
            q[‘classification_id__in‘] = [class_id,]

    else:
        print(‘方向不为0‘)
        # 方向选择某一个方向,
        # 如果分类是0
        if kwargs.get(‘classification_id‘) == ‘0‘:
            print(‘分类为0‘)
            # 获取已选择的视频方向
            obj = models.Direction.objects.get(id=int(kwargs.get(‘direction_id‘)))
            # 获取该方向的所有视频分类
            class_list = obj.classification.all().values(‘id‘, ‘name‘)
            # 获取所有视频分类对应的视频分类id
            id_list = list(map(lambda x: x[‘id‘], class_list))
            # 过滤条件为视频分类id in [该方向下的所有视频分类id]
            q[‘classification_id__in‘] = id_list
        else:
            # 方向不为0,分类也不为0
            obj = models.Direction.objects.get(id=int(kwargs.get(‘direction_id‘)))
            class_list = obj.classification.all().values(‘id‘, ‘name‘)
            id_list = list(map(lambda x:x[‘id‘], class_list))
            # 过滤条件为视频分类id in [已经选择的视频分类id]
            q[‘classification_id__in‘] = [class_id,]
            print(‘分类不为0‘)
            # 当前分类如果在获取的所有分类中,则方向下的所有相关分类显示
            # 当前分类如果不在获取的所有分类中,
            if int(kwargs.get(‘classification_id‘)) in id_list:
                pass
            else:
                print(‘不再,获取指定方向下的所有分类:选中的回到全部‘)
                url_part_list = request_path.split(‘-‘)
                url_part_list[2] = ‘0‘
                request_path = ‘-‘.join(url_part_list)
    # 视频等级id
    level_id = int(kwargs.get(‘level_id‘))
    if level_id == 0:
        pass
    else:
        # 过滤条件增加视频等级
        q[‘level‘] = level_id 

    # 取出相对应的视频
    video_list = models.Video.objects.filter(**q).values(‘title‘,‘summary‘, ‘img‘, ‘href‘)
    # 把视频等级转化为单个标签是字典格式,整体是列表格式
    ret = map(lambda x:{"id": x[0], ‘name‘: x[1]}, models.Video.level_choice)
    level_list = list(ret)
    return render(request, ‘video.html‘, {‘direction_list‘: direction_list,
                                          ‘class_list‘: class_list,
                                          ‘level_list‘: level_list,
                                          ‘current_url‘: request_path,
                                          "video_list": video_list})
时间: 2024-10-22 11:53:21

django多条件筛选搜索(项目实例)的相关文章

jquery实现多条件筛选特效代码分享

本文实例讲述了jquery实现多条件筛选特效.分享给大家供大家参考.具体如下:jquery实现的多条件搜索表单带日期选择表格表单效果源码,是一段实现了多个条件筛选搜索的特效代码,多条件拥有时间.地点.酒店位置及酒店名称等选项,同时在时间的输入表格中拥有时间选择功能,是一款非常实用的特效代码,值得大家学习.运行效果图:                        -------------------查看效果 下载源码------------------- Javashop商城系统,专业_省心

HBase多条件筛选查询方案

最近的项目需要使用Hbase做实时查询,由于Hbase只支持一级索引,也就是使用rowkey作为索引查询,所以对于多条件筛选查询的支持不够,在不建立二级索引的情况下,只能使用Hbase API中提供的各种filter过滤器进行筛选,感觉查询效率不太理想,于是考虑建立二级索引的方案. 经过google学习网上前辈们的经验,暂时找到两种可用的方案: 使用Hbase协处理器Coprocessor在写入数据时,创建二级索引表,并将每条数据的索引写入二级索引表中,查询时先根据筛选条件查询二级索引表,获取相

关于进行条件筛选的SQL关键字的一点理解

概述 一般能够用于条件筛选的有三种: ON: 联结(join)筛选 WHERE: 一般条件筛选 HAVING: 分组后的条件筛选 ON JOIN – ON 语句的执行顺序: 例句: SELECT * FROM A LEFT JOIN B ON A.ID = B.ID AND A<>0 WHERE A.name = 'x' 注意在作on 连接后 的and 子句 和where 子句 . 他们有什么不同? 逻辑上解释:(不考虑执行计划中执行步骤和作嵌套连接等具体方式,这里只讨论如何思考逻辑上的步骤)

关于web多标签多条件筛选的思考

做项目的过程中,发现一次远程链接数据库的耗时大概是300ms~400ms,切身体会到了前辈们经常说的减少链接的重要性,用了缓存后页面的打开时间从1.5s减少到400ms 前提: 那么来说一说正题,web中多标签多条件筛选的设计.有两个思路: 一种是通过页面刷新来获取数据 一种是通过ajax来异步获取数据 思考: 大的方向两条,分支很多,想搜索一下有没有最优方案,似乎找不到. spike: //js来获取用户点击的标签,拼装url,再用window.location.href=url来跳转. a标

织梦CMS实现多条件筛选功能

用织梦实现筛选的功能,其实主要就是运用到了织梦的高级搜索功能,然后用ajax去post替换掉本来的结果就可以了. 其实筛选的话,主要有两个问题需要解决,一个是前台的筛选实现,一个是后台根据前台的点击,反馈出相应的结果. 于是在网上搜索了N多的资料了之后,先实现前台的功能,就是你点了之后会有一个筛选的效果出来,当然,也只是一个效果.具体可以参照:jquery仿京东筛选效果.下面就一步一步用织梦来实现这样的功能. 首先我们先在后台自定义模型(自定义模型都不会的同学,可以直接去面壁思过了) 看到参照网

iOS: 悬浮的条件筛选框使用二

一.介绍: 在前面已经介绍了一种条件悬浮框,使用的是tableView的Plain分组样式实现的,因为这是tableView本身就具备的功能,分组悬浮效果.这次我来介绍第二种更加简单的方法,采用两个ScrollView来实现. 二.实现技术: (1)两个ScrollView,一个是左右滚动,成为内容视图,另一个是上下滚动,作为容器视图: (2) 创建头视图,头视图中有banner图和条件筛选框,标记banner图的高: (3)合理设置上下滚动的容器视图的frame,它承载头视图和内容视图,不过需

Jquery特效之=》仿京东多条件筛选特效

仿京东多条件筛选特效 品牌: 全部 惠普(hp) 联想(Lenovo) 联想(ThinkPad) 宏基(acer) 华硕 戴尔 三星 索尼 东芝 Gateway 微星 海尔 清华同方 富士通 苹果(Apple) 神舟 方正 优雅 价格: 全部 1000-2999 3000-3499 3500-3999 4000-4499 4500-4999 5000-5999 6000-6999 7000-9999 10000以上 尺寸: 全部 8.9英寸及以下 11英寸 12英寸 13英寸 14英寸 15英寸

第三百七十一节,Python分布式爬虫打造搜索引擎Scrapy精讲—elasticsearch(搜索引擎)用Django实现我的搜索以及热门搜索

第三百七十一节,Python分布式爬虫打造搜索引擎Scrapy精讲-elasticsearch(搜索引擎)用Django实现我的搜索以及热门 我的搜素简单实现原理我们可以用js来实现,首先用js获取到输入的搜索词设置一个数组里存放搜素词,判断搜索词在数组里是否存在如果存在删除原来的词,重新将新词放在数组最前面如果不存在直接将新词放在数组最前面即可,然后循环数组显示结果即可 热门搜索实现原理,当用户搜索一个词时,可以保存到数据库,然后记录搜索次数,利用redis缓存搜索次数最到的词,过一段时间更新

iOS: 悬浮的条件筛选下拉框的使用

1.介绍 app中条件筛选视图是很常用的功能,一般它搭配着tableView的表头悬浮滚动使用,点击按钮时,就会弹出下拉框显示条件,选择一个条件后,下拉框自动隐藏. 2.效果图如下 从中间点击弹出,然后滚动tableView随着移动,到顶部就悬浮着,下拉时仍然跟着滚动,一直滚动初始位置就停止...   3.实现方式 首先:采用分组的tableView,不过类型必须选择为Plain,这种类型本身就带悬浮效果.如果用Group类型,就没有悬浮效果: //设置tableView风格 -(instanc