zoukankan      html  css  js  c++  java
  • CRM 日期字段过滤功能——第21天

    1、CRM 日期字段过滤功能

    日期这个字段不像之前的数据是有choices、ForeignKey类型,在数据库中日期是有两个类型"DateTimeField","DateField",也不像之前的有下拉框数据让你选择,

    所以日期得自己先保存几个时间点,然后在判断如果是时间类型的筛选数数在select name 加上gte属于大于这个时间的数据展示在页面 <select name="_gte"></select>

    先导入时间模块datetime,timedelta 使用django的时间模块如下:

    from django.utils.timezone import datetime,timedelta

    1.1 判断字段的类型在"DateTimeField","DateField",创建的每个时间点放在一个list里面,然后去遍历他,然后加上<option></option>,再<select name="_gte"></select>,注如果不是时间类型name是不要加上_gte的,代码如下:

        if type(filed_obj).__name__ in ["DateTimeField","DateField"]:
            selected =''
            today_ele = datetime.now().date()
            date_eles = []
            date_eles.append(("今天",today_ele))
            date_eles.append(("7天",today_ele-timedelta(days=7)))
            date_eles.append(("本月",today_ele.replace(day=1)))
            date_eles.append(("半年",today_ele-timedelta(days=180)))
            date_eles.append(("一年",today_ele.replace(month=1,day=1)))
            for dateEle in date_eles:
                select_ele += '''<option value='%s'%s>%s</option>''' % (dateEle[1], selected,dateEle[0])
    
            condtion_name = "%s__gte"%(condtion)
    
        else:
            condtion_name = condtion
    #今天 
    today_time = datetime.now().date()
    >>> today_time
    datetime.date(2019, 8, 11)
    
    #这个月初
    >>> today_mouth = today_time.replace(day=1)
    >>> today_mouth
    datetime.date(2019, 8, 1)
    
    #今年初
    >>> today_year = today_time.replace(month=1,day=1)
    >>> today_year
    datetime.date(2019, 1, 1)

    完整代码如下:

    @register.simple_tag
    def render_filter_ele(condtion,admin_class,filter_condtions):
        #后台返回筛选框里面的值
        """
        :param condtion: 需要过滤的字段名
        :param admin_class: 比如Customer
        :param filter_condtions: 前端请求数据的json
        :return:
        """
        select_ele = '''<select class="form-control" name='{condtion_name}'><option value=''>----</option>'''
        filed_obj = admin_class.model._meta.get_field(condtion)
        #判断如果是choices类型
        if filed_obj.choices:
            selected=''
            for choice_item in filed_obj.choices:
                print("choice", choice_item, filter_condtions.get(condtion), type(filter_condtions.get(condtion)))
                if filter_condtions.get(condtion) == str(choice_item[0]):
                    selected = "selected"
    
                select_ele+='''<option value='%s' %s>%s</option>'''%(choice_item[0],selected,choice_item[1])
                selected=''
        #判断如果是属于ForeignKey类型的时候
        if type(filed_obj).__name__ == 'ForeignKey':
            selected = ''
            for choice_item in filed_obj.get_choices()[1:]:
                if filter_condtions.get(condtion) == str(choice_item[0]):
                    selected ="selected"
    
    
                select_ele += '''<option value='%s' %s>%s</option>''' % (choice_item[0], selected, choice_item[1])
                selected = ''
        #判断是属于日期类型的时候
        if type(filed_obj).__name__ in ["DateTimeField","DateField"]:
            selected =''
            today_ele = datetime.now().date()
            date_eles = []
            date_eles.append(("今天",today_ele))
            date_eles.append(("7天",today_ele-timedelta(days=7)))
            date_eles.append(("本月",today_ele.replace(day=1)))
            date_eles.append(("半年",today_ele-timedelta(days=180)))
            date_eles.append(("一年",today_ele.replace(month=1,day=1)))
            for dateEle in date_eles:
                select_ele += '''<option value='%s'%s>%s</option>''' % (dateEle[1], selected,dateEle[0])
    
            condtion_name = "%s__gte"%(condtion)
    
        else:
            condtion_name = condtion
    
        select_ele+="<select/>"
    
        select_ele= select_ele.format(condtion_name=condtion_name)
    
        return mark_safe(select_ele)
  • 相关阅读:
    处理i18n国际电话区号的代码实践
    iOS 万能跳转界面方法 (runtime实用篇一)
    URI跳转方式地图导航的代码实践
    iOS @IBDesignable和@IBInspectable
    我的iOS高效编程秘诀—坚持编程习惯
    如何手动解析CrashLog
    小心别让圆角成了你列表的帧数杀手
    iOS开发之使用Runtime给Model类赋值
    POP介绍与使用实践(快速上手动画)
    NSString&NSMutableString常用操作梳理
  • 原文地址:https://www.cnblogs.com/venvive/p/11335875.html
Copyright © 2011-2022 走看看