我的第一个python web开发框架(17)——产品管理

和黑猫之家聊聊?

  这是后台管理系统最后一个功能,产品管理,它的接口与页面功能与上一章差不多。

我的第一个python web开发框架(17)——产品管理 python教程 第1张

 

我的第一个python web开发框架(17)——产品管理 python教程 第2张

 

  获取产品列表接口

我的第一个python web开发框架(17)——产品管理 python教程 第3张

View Code

  这个接口多了按产品分类id查询的条件,如果少了这个的话,直接将产品分类字段替换为产品字段变量就可以了。

  大家可以看到这里的代码好像有点复杂。是的,这里要进行分页查询进行了分页处理,所以代码有点多,不过写了很详细的注释,只要你对python的基本语法、字典的处理理解,然后对之前工具函数那里按要求重写过测试用例,那么对阅读这段代码是没有什么大问题的。

  下面再重新帮大家熟悉一下前面讲述过的工具函数

product_class_id = convert_helper.to_int0(web_helper.get_query('product_class_id', '产品分类id', is_check_null=False))

  这是获取客户端(HTML)用AJAX提交上来的产品分类id接收处理,如果你认真看过前面工具函数内容的话,看到web_helper.get_query()这个函数应该会很熟悉,它就是获取GET方式提交值的接收函数,第一个参数是要接收的变量名称,第二个参数是这个变量的中文说明,第三个是在接收参数时,是否做非空判断,当前设置为这不是必填项。默认它为True,当为True时,如果客户端没有提交这个参数值,则系统自动会返回“xxx 不允许为空”,这个xxx就是第二个参数,也就是当前变量的中文说明,还有其他参数大家可以打看web_helper.py查看。

  convert_helper.to_int0()这个函数,在前面工具函数第一篇中讲到的函数,它会将接收到的参数字符串转为int类型值,如果这个参数小于0时,会自动使用默认值0代替。

 

sql = 'select count(1) as records from product %(wheres)s' % {'wheres': wheres}

  使用习惯ORM的朋友可能会不太习惯直接写sql语句,本系列第一部分主要面向没有什么基础的朋友,所以尽量不封装各种类和函数,这样大家直接看到内容会更容易理解。第二部分会教大家自己简单封装一个ORM,到时重构后重复代码就会减少一大半。

  上面这行是获取当前查询有多少条记录的sql语句,熟悉python字符串替换的朋友应该会很熟悉,它会将字符串%后面的字典内容替代字符串中对应的键值,如果wheres值为空时,则替换空值,即将%(wheres)s这个键值替换掉。

  python的字符串替换有多种方式,而这里使用字典方式来替换会让代码可读性更高,而且字典中各个值的位置不需要按固定方式摆放,不容易出错。

 

  获取指定id的记录实体

我的第一个python web开发框架(17)——产品管理 python教程 第4张

 1 @get('/api/product/<id:int>/') 2 def callback(id): 3     """ 4     获取指定记录 5     """ 6     sql = """select * from product where id = %s""" % (id,) 7     # 读取记录 8     result = db_helper.read(sql) 9     if result:10         # 直接输出json11         return web_helper.return_msg(0, '成功', result[0])12     else:13         return web_helper.return_msg(-1, "查询失败")

我的第一个python web开发框架(17)——产品管理 python教程 第5张

  这段代码比较简单,第6行使用的就是%s替换字符串方式,后面的元组(id,)  好像python3以后元组里不加逗号替换也没有问题,python2是一定要加的。

 

  添加产品与修改产品接口

我的第一个python web开发框架(17)——产品管理 python教程 第6张

View Code

  使用非get方式提交时,即使用post、put、delete等方式提交参数时,需要使用web_helper.get_form()函数来接收,这一点大家要注意,不然就会获取不到客户端提交的参数值

我的第一个python web开发框架(17)——产品管理 python教程 第7张

    # 添加记录(使用returning这个函数能返回指定的字段值,这里要求返回新添加记录的自增id值)
    sql = """insert into product (name, code, product_class_id, standard, quality_guarantee_period,
                place_of_origin, front_cover_img, content, is_enable)
              values (%s, %s, %s, %s, %s, %s, %s, %s, %s) returning id"""
    vars = (name, code, product_class_id, standard, quality_guarantee_period, place_of_origin, front_cover_img, content, is_enable)    # 写入数据库
    result = db_helper.write(sql, vars)

我的第一个python web开发框架(17)——产品管理 python教程 第8张

  新增记录时,容易出错的地方是参数中的%s与字段数量不匹配,这里大家要注意一下。另外,在insert语句的后尾最好加上returning id或returning *  返回新增记录值或整个记录实体,方便用来判断是否插入成功,如果返回这些内容的话,比较难判断数据库记录是否添加成功了

我的第一个python web开发框架(17)——产品管理 python教程 第9张

    # 编辑记录
    sql = """
          update product
            set name=%s, code=%s, product_class_id=%s, standard=%s, quality_guarantee_period=%s,
                place_of_origin=%s, front_cover_img=%s, content=%s, is_enable=%s
          where id=%s returning id"""
    vars = (name, code, product_class_id, standard, quality_guarantee_period, place_of_origin, front_cover_img, content,
            is_enable, id)    # 写入数据库
    result = db_helper.write(sql, vars)

我的第一个python web开发框架(17)——产品管理 python教程 第10张

  更新记录时,参数元组中记录要将记录的id值放进来,不然也会出现sql执行异常的问题,这个也是容易出错的地方。

 

  删除记录接口

我的第一个python web开发框架(17)——产品管理 python教程 第11张

 1 @delete('/api/product/<id:int>/') 2 def callback(id): 3     """ 4     删除指定记录 5     """ 6     # 编辑记录 7     sql = """delete from product where id=%s returning id""" 8     vars = (id,) 9     # 写入数据库10     result = db_helper.write(sql, vars)11     # 判断是否提交成功12     if result:13         return web_helper.return_msg(0, '成功')14     else:15         return web_helper.return_msg(-1, "删除失败")

我的第一个python web开发框架(17)——产品管理 python教程 第12张

  

  前端代码大家自己可以比较一下上一章,看看有什么不同

  非常感谢Sunshine-X 的提醒,在产品编辑页面的js中,添加了保存成功后jqgrid表格刷新代码(本人前端比较菜)

  后面附上完整的项目代码

 

  本文对应的源码下载

 

微信搜索公众号黑猫之家看更多资讯哦

来黑猫之家看看呗

发表评论:

◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。

Copyright © 2015-2018 黑猫吧(www.heimaoba.cn) 赣ICP备18005425号-1