Python3+flask+sqlalchemy分页查询

Flask是Python3开发平台的小型框架,是DJango框架的轻量版,所谓的轻量,并不是说Flask功能没有DJango强大,而是为了提供用户开发过程中更大的灵活空间,缩减了很多框架性的东西,而不会自动生成框架性的代码。为了开发的灵活性,Flask提供了很多扩展库,如Flask-sqlalchemy,就是对数据库操作的扩展库。

平台开发,咱们经常碰到的就是分页展示功能,几乎每个平台都会使用到,而Flask-sqlalchemy分页采用paginate方法,简单粗暴,直接上代码,以下是获取用户列表的分页代码:

@user_sys.route (“/user/query”,methods =[‘GET’])
def query_users ():

判断当前登陆的用户有效性

if not isCurrentUserValid(current_user):
return getResultAnd2Josn(CODE_CURRENT_USER_INVALID ,MSG_CURRENT_USER_INVALID ,{})

接收并解析请求的json数据

res = request.get_data()
data = json.loads(res)

当前选中的组织机构ID(按需求来,该项目的需求是查看当前组织机构的用户列表)

organization_id = data.get(‘organization_id’)
if organization_id

请求的页码

page_num = data.get(‘page_num’)

每页展示数量

data_count = data.get(‘data_count’)

排序, 1-注册时间降序;2-注册时间升序;3-姓名降序;4-姓名升序

order_by = data.get(‘order_by’)
if page_num >=0 and data_count >0 :
user_order_by = User.createDate.desc()
if 2 == order_by:
user_order_by = User.createDate.asc()
elif 3 == order_by:

为了兼容中文,需要CONVERT

user_order_by = func.CONVERT(literal_column(‘name using gbk’)).desc()
elif 4 == order_by:
user_order_by = func.CONVERT(literal_column(‘name using gbk’)).asc()

搜索字符串

filter = data.get(‘filter’)
if None == filter or len (filter) ==0 :
my_current_user = getCurrentuser()
if my_current_user:
if not is_common_user(my_current_user):
organization = Organization.query.get(my_current_user.organizationId)
sub_organization_ids = organization.get_all_sub_organizations_id()
sub_organization_ids.append(organization_id)

# 重点:分页用户列表,通过BaseQuery类的paginate方法进行分页查询,返回Pagination实例,该该包含了数据列表、数据总量,当前页等信息
user_paginate = User.query.order_by(user_order_by).filter(User.organizationId.in_(sub_organization_ids)).paginate(page =page_num ,per_page =data_count)

返回json给前端

return get_json_users_by_user_paginate(user_paginate)
else :

my_organization_id = my_current_user.organizationId

user_paginate = User.query.order_by(user_order_by).filter(and_(User.organizationId == organization_id ,User.id == my_current_user.id)).paginate(page =page_num ,per_page =data_count)
return get_json_users_by_user_paginate(user_paginate)
else :
return getResultAnd2Josn(CODE_CURRENT_USER_INVALID ,MSG_CURRENT_USER_INVALID ,{})
else :
my_current_user = getCurrentuser()
if my_current_user:
if not is_common_user(my_current_user):
organization = Organization.query.get(my_current_user.organizationId)
sub_organization_ids = organization.get_all_sub_organizations_id()
sub_organization_ids.append(organization_id)
user_paginate = User.query.order_by(user_order_by).filter(and_(User.organizationId.in_(sub_organization_ids),or_(User.name.like(‘%’+filter+”%”),User.account.like(‘%’+ filter +”%”))),and_(User.organizationId == organization_id)).paginate(page =page_num ,per_page =data_count)
return get_json_users_by_user_paginate(user_paginate)
else :
user_paginate = User.query.order_by(user_order_by).filter(
and_(User.organizationId == organization_id ,User.id == my_current_user.id ,
or_(User.name.like(‘%’+ filter +’%’),User.account.like(‘%’+ filter +’%’))),
and_(User.organizationId == organization_id)).paginate(page =page_num ,per_page =data_count)
return get_json_users_by_user_paginate(user_paginate)
else :
return getResultAnd2Josn(CODE_CURRENT_USER_INVALID ,MSG_CURRENT_USER_INVALID ,{})
return getResultAnd2Josn(CODE_FAILED ,MSG_FAILED ,{‘total’:0 ,’items’: []})

Original: https://blog.csdn.net/weishengwen2/article/details/125300851
Author: 板砖也快乐
Title: Python3+flask+sqlalchemy分页查询



相关阅读

Title: 关于新版本selenium定位元素报错:‘WebDriver‘ object has no attribute ‘find_element_by_id‘等问题

由于一段时间没有使用Selenium,当再次使用时发现之前写的Selenium元素定位的代码运行之后会报错,发现是Selenium更新到新版本(4.x版本)后,以前的一些常用的代码的语法发生了改变,当然如果没有更新过或是下载最新版本的Selenium是不受到影响的,还可以使用以前的写法。接下来就是讨论有关于新版本后Selenium定位元素代码的新语法。

改动一:executable_path

旧版本Selenium代码:

from selenium import webdriver
driver=webdriver.Chrome(executable_path='/home/yan/Python/chromeselenium/chromeselenium/chromedriver')

executable_path是我们Selenium驱动的存放路径,只有使用executable_path指定出该路径,Selenium才能正常工作,但是Selenium经过版本更新之后,在使用如上写法时,系统就会报错executable_path has been deprecated, please pass in a Service object,如下所示:

DeprecationWarning: executable_path has been deprecated, please pass in a Service object
  driver = webdriver.Chrome(executable_path="/home/yan/Python/chromeselenium/chromeselenium/chromedriver")

意思是:executable_path已被弃用,请传入一个Service对象,于是我们就需要修改为如下代码:

新版本Selenium代码:

from selenium import webdriver
from selenium.webdriver.chrome.service import Service

service = Service(executable_path='/home/yan/Python/chromeselenium/chromeselenium/chromedriver')

driver = webdriver.Chrome(service=service)

driver.get("网址")

改动二:Selenium定位元素代码

在旧版本中,我们大多数都是使用以下代码来进行元素的定位
旧版本Selenium元素定位代码:


inputTag = driver.find_element_by_id("value")

inputTags = driver.find_element_by_class_name("value")

inputTag = driver.find_element_by_name("value")

inputTag = driver.find_element_by_tag_name("value")

inputTag = driver.find_element_by_xpath("value")

inputTag = driver.find_element_by_css_selector("value")

在版本没有更新前我们使用的都是 driver.find_element_by_方法名(“value”), 方法名就是by_id、by_class_name、by_name等等,而”value”,则是传入的值,以百度搜索框为例,右键点击百度搜索框点击检查则可看其HTML源代码中属性 id=”kw”,以旧版本的写法使用id值查找搜索框应该是:

inputTag = driver.find_element_by_id("kw")

Python3+flask+sqlalchemy分页查询

在版本没有更新之前,通常情况下运行都是能够正确定位到对应的元素,但是Selenium经过版本升级之后,运行后会报错,以driver.find_element_by_id(“value”)为例(其他报错也是类似下面的报错信息),运行后会报错,如下:

Python3+flask+sqlalchemy分页查询

根据官方最新文档,将代码进行修改,修改后的格式由 driver.find_element_by_方法名(“value”)变为 driver.find_element(By.方法名, “value”),具体改动如下:

新版本Selenium代码:
首先在文件头部引入如下代码

from selenium.webdriver.common.by import By

而后做如下修改:


inputTag = driver.find_element(By.ID, "value")

inputTag = driver.find_element(By.CLASS_NAME, "value")

inputTag = driver.find_element(By.NAME, "value")

inputTag = driver.find_element(By.TAG_NAME, "value")

inputTag = driver.find_element(By.XPATH, "value")

inputTag = driver.find_element(By.CSS_SELETOR, "value")

修改完之后即可使用selenium进行自动化工作!

Original: https://blog.csdn.net/m0_49076971/article/details/126233151
Author: 热爱学习的猪
Title: 关于新版本selenium定位元素报错:‘WebDriver‘ object has no attribute ‘find_element_by_id‘等问题

原创文章受到原创版权保护。转载请注明出处:https://www.johngo689.com/302927/

转载文章受原作者版权保护。转载请注明原作者出处!

(0)

大家都在看

最近整理资源【免费获取】:   👉 程序员最新必读书单  | 👏 互联网各方向面试题下载 | ✌️计算机核心资源汇总