本文整理匯總了Python中uliweb.utils.generic.ListView.query方法的典型用法代碼示例。如果您正苦於以下問題:Python ListView.query方法的具體用法?Python ListView.query怎麽用?Python ListView.query使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類uliweb.utils.generic.ListView
的用法示例。
在下文中一共展示了ListView.query方法的11個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。
示例1: list
# 需要導入模塊: from uliweb.utils.generic import ListView [as 別名]
# 或者: from uliweb.utils.generic.ListView import query [as 別名]
def list(self):
from uliweb.utils.generic import ListView
pageno = request.GET.get("page", 0)
view = ListView(self.model, pageno=pageno, order_by=self.model.c.publish_date.desc())
return {"blogs": view.query(), "view": view, "count": view.query().count()}
示例2: list
# 需要導入模塊: from uliweb.utils.generic import ListView [as 別名]
# 或者: from uliweb.utils.generic.ListView import query [as 別名]
def list(self):
from uliweb.utils.generic import ListView
pageno = request.GET.get('page', 0)
view = ListView(self.model, pageno=pageno, order_by=self.model.c.publish_date.desc())
return {'blogs':view.query(), 'view':view, 'count':view.query().count()}
示例3: list
# 需要導入模塊: from uliweb.utils.generic import ListView [as 別名]
# 或者: from uliweb.utils.generic.ListView import query [as 別名]
def list(self):
from uliweb import request
from uliweb.utils.generic import ListView
from uliweb.utils.common import get_choice
import math
pageno = int(request.values.get('page', 1)) - 1
rows_per_page=int(request.values.get('rows', settings.get_var('MESSAGES/PAGE_NUMS', 10)))
read_flag = request.GET.get('read', '')
type_flag = request.GET.get('type', '')
condition = None
condition = (self.model.c.user == request.user.id) & condition
condition = (self.model.c.send_flag == 'r') & condition
if read_flag:
condition = (self.model.c.read_flag == bool(read_flag=='1')) & condition
if type_flag:
condition = (self.model.c.type == type_flag) & condition
def create_date(value, obj):
from uliweb.utils.timesince import timesince
return timesince(value)
def user_image(value, obj):
return functions.get_user_image(obj.sender, size=20)
def message(value, obj):
return value
fields_convert_map = {'create_date':create_date,
'user_image':user_image,
'message':message}
view = ListView(self.model, condition=condition,
order_by=[self.model.c.create_date.desc()],
rows_per_page=rows_per_page, pageno=pageno,
fields_convert_map=fields_convert_map)
view.query()
result = {}
result['read_flag'] = read_flag
result['type_flag'] = type_flag
result['message_type_name'] = get_choice(settings.get_var('MESSAGES/MESSAGE_TYPE'), type_flag, '全部類型')
pages = int(math.ceil(1.0*view.total/rows_per_page))
# result['page'] = pageno+1
# result['total'] = view.total
# result['pages'] = pages
result['pagination'] = functions.create_pagination(functions.request_url(), view.total, pageno+1, rows_per_page)
result['objects'] = list(view.objects())
ids = []
for row in result['objects']:
ids.append(row._obj_.id)
self.model.filter(self.model.c.id.in_(ids)).update(read_flag=True)
_del_key(request.user.id)
return result
示例4: sended_list
# 需要導入模塊: from uliweb.utils.generic import ListView [as 別名]
# 或者: from uliweb.utils.generic.ListView import query [as 別名]
def sended_list(self):
from uliweb import request
from uliweb.utils.generic import ListView
from uliweb.utils.common import get_choice
import math
pageno = int(request.values.get("page", 1)) - 1
rows_per_page = int(request.values.get("rows", settings.get_var("MESSAGES/PAGE_NUMS", 10)))
read_flag = request.GET.get("read", "")
type_flag = request.GET.get("type", "")
condition = None
condition = (self.model.c.sender == request.user.id) & condition
condition = (self.model.c.send_flag == "s") & condition
if read_flag:
condition = (self.model.c.read_flag == bool(read_flag == "1")) & condition
if type_flag:
condition = (self.model.c.type == type_flag) & condition
def create_date(value, obj):
from uliweb.utils.timesince import timesince
return timesince(value)
def user_image(value, obj):
return functions.get_user_image(obj.user, size=20)
def message(value, obj):
return value
fields_convert_map = {"create_date": create_date, "user_image": user_image, "message": message}
view = ListView(
self.model,
condition=condition,
order_by=[self.model.c.create_date.desc()],
rows_per_page=rows_per_page,
pageno=pageno,
fields_convert_map=fields_convert_map,
)
view.query()
result = {}
result["read_flag"] = read_flag
result["type_flag"] = type_flag
result["message_type_name"] = get_choice(settings.get_var("MESSAGES/MESSAGE_TYPE"), type_flag, "全部類型")
pages = int(math.ceil(1.0 * view.total / rows_per_page))
# result['page'] = pageno+1
# result['total'] = view.total
# result['pages'] = pages
result["pagination"] = functions.create_pagination(request.url, view.total, pageno + 1, rows_per_page)
result["objects"] = view.objects()
return result
示例5: view
# 需要導入模塊: from uliweb.utils.generic import ListView [as 別名]
# 或者: from uliweb.utils.generic.ListView import query [as 別名]
def view(self):
#objects = self.blogs.all()
# model = functions.get_model('blogs').all()
# print self.blogs
# print model
# return {'objects':model}
from uliweb.utils.generic import ListView
pageno = int(request.GET.get('page',1)) - 1
rows_per_page = int(request.GET.get('rows', 8))
view = ListView(self.blogs, order_by=self.blogs.c.modified_time.desc(), pageno=pageno, rows_per_page=rows_per_page)
view.query()
pagination = functions.create_pagination(request.url, view.total, pageno+1, rows_per_page)
return {'objects': view.objects(),'pagination': pagination}
示例6: test
# 需要導入模塊: from uliweb.utils.generic import ListView [as 別名]
# 或者: from uliweb.utils.generic.ListView import query [as 別名]
def test(self):
from uliweb.utils.generic import ListView
print functions
#頁麵編號
pageno = int(request.GET.get('page', 1)) - 1
#每頁文章數量,5為每頁顯示的文章
rows_per_page = int(request.GET.get('rows', 8))
print int(request.GET.get('rows', 1))
#後麵的參數為請求網址,所有記錄數, 總頁數, 每頁文章數
def modified_date(value, obj):
return self._get_date(obj.modified_date)
#fields_convert_map = {'modified_date': modified_date}
#view = ListView(self.model, order_by=self.model.c.modified_time.desc(), pageno=pageno, rows_per_page=rows_per_page, fields_convert_map=fields_convert_map)
view = ListView(self.model, order_by=self.model.c.modified_time.desc(), pageno=pageno, rows_per_page=rows_per_page)
view.query()
pagination = functions.create_pagination(request.url, view.total, pageno+1, rows_per_page)
return {'objects': view.objects(),'pagination': pagination}
示例7: index
# 需要導入模塊: from uliweb.utils.generic import ListView [as 別名]
# 或者: from uliweb.utils.generic.ListView import query [as 別名]
def index(self):
"""
教程顯示首頁
"""
from uliweb.utils.generic import ListView
condition = (self.model.c.deleted==False)
pageno = int(request.GET.get('page', 1)) - 1
rows_per_page = int(request.GET.get('rows', 10))
cateobjects = self.model_cate.all()
# def render(r, obj):
# from uliweb import Storage
#
# data = Storage(dict(r))
# data['image'] = obj.get_image()
# data['author'] = unicode(obj.modified_user)
# data['modified_date'] = self._get_date(obj.modified_date)
# return data
def image(value, obj):
return obj.get_image()
def author(value, obj):
return unicode(obj.modified_user)
def modified_date(value, obj):
return self._get_date(obj.modified_date)
fields_convert_map = {'image':image, 'author':author, 'modified_date':modified_date}
view = ListView(self.model, condition=condition,
order_by=self.model.c.modified_date.desc(), pageno=pageno,
rows_per_page=rows_per_page, fields_convert_map=fields_convert_map)
view.query()
pagination = functions.create_pagination(request.url, view.total, pageno+1,
rows_per_page)
return {'pagination':pagination, 'objects':view.objects(),'cateobjects':cateobjects}
示例8: topic_view
# 需要導入模塊: from uliweb.utils.generic import ListView [as 別名]
# 或者: from uliweb.utils.generic.ListView import query [as 別名]
#.........這裏部分代碼省略.........
get_user_image = function('get_user_image')
try:
url = get_user_image(obj.posted_by)
except NotFound:
url = get_user_image()
return url
def actions(value, obj):
if not request.user:
return ''
a = []
is_manager = forum.managers.has(request.user)
if obj.floor == 1 and obj.parent == None:
#第一樓為主貼,可以允許關閉,頂置等操作
if is_manager:
a.append('<a href="#" rel="%d" class="close_thread">%s</a>' % (obj.id, self.status['close'][obj.topic.closed]))
a.append('<a href="#" rel="%d" class="hidden">%s</a>' % (obj.id, self.status['hidden'][obj.topic.hidden]))
a.append('<a href="#" rel="%d" class="top">%s</a>' % (obj.id, self.status['sticky'][obj.topic.sticky]))
a.append('<a href="#" rel="%d" class="essence">%s</a>' % (obj.id, self.status['essence'][obj.topic.essence]))
a.append('<a href="#" rel="%d" class="homepage">%s</a>' % (obj.id, self.status['homepage'][obj.topic.homepage]))
if is_manager or (obj.posted_by.id == request.user.id and obj.created_on+timedelta(days=settings.get_var('PARA/FORUM_EDIT_DELAY'))>=date.now()):
#作者或管理員且在n天之內,則可以編輯
url = url_for(ForumView.edit_topic, forum_id=forum_id, topic_id=topic_id)
a.append('<a href="%s" rel="%d" class="edit">編輯</a>' % (url, obj.id))
if is_manager:
url = url_for(ForumView.remove_topic, forum_id=forum_id, topic_id=topic_id)
a.append('<a href="%s" rel="%d" class="delete_topic">刪除主題</a>' % (url, obj.id))
#處理貼子轉移,管理員可以轉移
if is_manager or request.user.is_superuser:
url = url_for(ForumView.move_topic, forum_id=forum_id, topic_id=topic_id)
a.append('<a href="%s" rel="%d" class="move_topic">移動主題</a>' % (url, obj.id))
if is_manager or (obj.posted_by.id == request.user.id):
if (obj.deleted and (obj.deleted_by.id == request.user.id or is_manager)) or not obj.deleted:
a.append('<a href="#" rel="%d" class="delete">%s</a>' % (obj.id, self.status['delete'][obj.deleted]))
try:
obj.posted_by
if obj.posted_by.id == request.user.id:
a.append('<a href="#" rel="%d" class="email">%s</a>' % (obj.id, self.status['email'][obj.reply_email]))
except NotFound:
obj.posted_by = None
obj.save()
a.append('<a href="/%d/%d/%d/new_reply">回複該作者</a>' % (forum_id, topic_id, obj.id))
return ' | '.join(a)
def updated(value, obj):
if obj.floor == 1 and obj.topic.updated_on and not obj.parent:
return u'<div class="updated">由 %s 於 %s 更新</div>' % (obj.topic.modified_user.username, timesince(obj.topic.updated_on))
fields = ['topic', 'id', 'username', 'userimage', 'posted_by', 'content',
'created_on', 'actions', 'floor', 'updated', 'parent',
]
fields_convert_map = {'created_on':created_on, 'content':content,
'username':username, 'userimage':userimage, 'actions':actions,
'updated':updated}
#view1 為生成一級回複,即回複主題
view1 = ListView(Post, fields=fields, condition=condition1, order_by=order_by,
rows_per_page=rows_per_page, pageno=pageno,
fields_convert_map=fields_convert_map)
#view2 為生成二級乃至多級回複
view2 = ListView(Post, fields=fields, condition=condition2, order_by=order_by,
pagination=False,
fields_convert_map=fields_convert_map)
key = '__topicvisited__:forumtopic:%s:%s:%s' % (request.remote_addr, forum_id, topic_id)
cache = function('get_cache')()
v = cache.get(key, None)
if not v:
Topic.filter(Topic.c.id==int(topic_id)).update(num_views=Topic.c.num_views+1)
cache.set(key, 1, settings.get_var('PARA/FORUM_USER_VISITED_TIMEOUT'))
slug = uuid.uuid1().hex
#處理posts和sub_posts
query = view1.query()
posts = []
sub_posts = {}
def process_sub(ids):
_ids = []
for x in Post.filter(Post.c.parent.in_(ids)).order_by(Post.c.floor):
obj = view2.object(x)
d = sub_posts.setdefault(str(x._parent_), [])
d.append(obj)
_ids.append(x.id)
if _ids:
process_sub(_ids)
ids = []
for row in query:
posts.append(view1.object(row))
ids.append(row.id)
process_sub(ids)
pagination = functions.create_pagination(request.path+'?'+request.query_string, view1.total,
pageno+1, rows_per_page)
return {'forum':forum, 'topic':topic, 'slug':slug,
'has_email':bool(request.user and request.user.email),
'page':pageno+1, 'pagination':pagination,
'posts':posts, 'sub_posts':sub_posts}
示例9: forum_index
# 需要導入模塊: from uliweb.utils.generic import ListView [as 別名]
# 或者: from uliweb.utils.generic.ListView import query [as 別名]
def forum_index(self, id):
"""
顯示某論壇頁麵
"""
from uliweb.utils.generic import ListView
from sqlalchemy.sql import and_
import math
pageno = int(request.values.get('page', 1)) - 1
rows_per_page=int(request.values.get('rows', settings.get_var('PARA/FORUM_INDEX_NUMS')))
Topic = get_model('forumtopic')
Forum = get_model('forum')
User = get_model('user')
forum = Forum.get(int(id))
condition = Topic.c.forum == int(id)
order_by = [Topic.c.sticky.desc(), Topic.c.last_reply_on.desc()]
if not forum.managers.has(request.user):
condition = (Topic.c.hidden==False) & condition
filter = request.GET.get('filter', 'all')
if filter == 'essence':
condition = (Topic.c.essence==True) & condition
elif filter == 'sticky':
condition = (Topic.c.sticky==True) & condition
term = request.GET.get('term', '')
type = request.GET.get('type', '1')
if term:
if type == '1': #查找主題
condition = (Topic.c.subject.like('%'+term+'%')) & condition
elif type == '2': #查找用戶名
condition = and_(Topic.c.posted_by == User.c.id,
User.c.username.like('%' + term + '%') | User.c.nickname.like('%' + term + '%'),
) & condition
def created_on(value, obj):
return value.strftime('%Y-%m-%d')
def last_reply_on(value, obj):
return timesince(value)
def subject(value, obj):
import cgi
if obj.topic_type:
_type = u'[%s]' % obj.get_display_value('topic_type')
else:
_type = ''
s = ''
if obj.sticky:
s += u'<font color="red">[頂]</font>'
if obj.hidden:
s += u'<font color="red">[隱]</font>'
if obj.closed:
s += u'<font color="red">[關]</font>'
if obj.essence:
s += u'<font color="red">[精]</font>'
if obj.homepage:
s += u'<font color="red">[首]</font>'
return _type+ '<a href="/%d/%d">%s</a>' % (int(id), obj.id, cgi.escape(obj.subject)) + s
fields_convert_map = {'created_on':created_on, 'subject':subject,
'last_reply_on':last_reply_on}
view = ListView(Topic, condition=condition, order_by=order_by,
rows_per_page=rows_per_page, pageno=pageno,
fields_convert_map=fields_convert_map)
view.query() #in order to get the total count
objects = view.objects()
pages = int(math.ceil(1.0*view.total/rows_per_page))
return {'forum':forum, 'objects':objects, 'filter':filter, 'term':term,
'page':pageno+1, 'total':view.total, 'pages':pages,
'pagination':functions.create_pagination(request.path+'?'+request.query_string, view.total, pageno+1, rows_per_page),
'type':type, 'filter_name':dict(settings.get_var('PARA/FILTERS')).get(filter)}
示例10: topic_view
# 需要導入模塊: from uliweb.utils.generic import ListView [as 別名]
# 或者: from uliweb.utils.generic.ListView import query [as 別名]
#.........這裏部分代碼省略.........
if is_manager or (obj.posted_by.id == request.user.id):
if (obj.deleted and (obj.deleted_by.id == request.user.id or is_manager)) or not obj.deleted:
a.append(
'<a href="#" rel="%d" class="delete">%s</a>' % (obj.id, self.status["delete"][obj.deleted])
)
if obj.posted_by.id == request.user.id:
a.append('<a href="#" rel="%d" class="email">%s</a>' % (obj.id, self.status["email"][obj.reply_email]))
a.append('<a href="/forum/%d/%d/%d/new_reply">回複該作者</a>' % (forum_id, topic_id, obj.id))
return " | ".join(a)
def updated(value, obj):
if obj.floor == 1 and obj.topic.updated_on and not obj.parent:
return u'<div class="updated">由 %s 於 %s 更新</div>' % (
obj.topic.modified_user.username,
timesince(obj.topic.updated_on),
)
fields = [
"topic",
"id",
"username",
"userimage",
"posted_by",
"content",
"created_on",
"actions",
"floor",
"updated",
"parent",
]
fields_convert_map = {
"created_on": created_on,
"content": content,
"username": username,
"userimage": userimage,
"actions": actions,
"updated": updated,
}
# view1 為生成一級回複,即回複主題
view1 = ListView(
Post,
fields=fields,
condition=condition1,
order_by=order_by,
rows_per_page=rows_per_page,
pageno=pageno,
fields_convert_map=fields_convert_map,
)
# view2 為生成二級乃至多級回複
view2 = ListView(
Post,
fields=fields,
condition=condition2,
order_by=order_by,
pagination=False,
fields_convert_map=fields_convert_map,
)
key = "__topicvisited__:forumtopic:%s:%s:%s" % (request.remote_addr, forum_id, topic_id)
cache = function("get_cache")()
v = cache.get(key, None)
if not v:
Topic.filter(Topic.c.id == int(topic_id)).update(num_views=Topic.c.num_views + 1)
cache.set(key, 1, settings.get_var("PARA/FORUM_USER_VISITED_TIMEOUT"))
slug = uuid.uuid1().hex
topic = Topic.get(int(topic_id))
# 處理posts和sub_posts
query = view1.query()
posts = []
sub_posts = {}
def process_sub(ids):
_ids = []
for x in Post.filter(Post.c.parent.in_(ids)).order_by(Post.c.floor):
obj = view2.object(x)
d = sub_posts.setdefault(str(x._parent_), [])
d.append(obj)
_ids.append(x.id)
if _ids:
process_sub(_ids)
ids = []
for row in query:
posts.append(view1.object(row))
ids.append(row.id)
process_sub(ids)
pagination = functions.create_pagination(request.url, view1.total, pageno + 1, rows_per_page)
return {
"forum": forum,
"topic": topic,
"slug": slug,
"has_email": bool(request.user and request.user.email),
"page": pageno + 1,
"pagination": pagination,
"posts": posts,
"sub_posts": sub_posts,
}
示例11: forum_index
# 需要導入模塊: from uliweb.utils.generic import ListView [as 別名]
# 或者: from uliweb.utils.generic.ListView import query [as 別名]
def forum_index(self, id):
"""
顯示某論壇頁麵
"""
from uliweb.utils.generic import ListView
from sqlalchemy.sql import and_
import math
pageno = int(request.values.get("page", 1)) - 1
rows_per_page = int(request.values.get("rows", settings.get_var("PARA/FORUM_INDEX_NUMS")))
Topic = get_model("forumtopic")
Forum = get_model("forum")
User = get_model("user")
forum = Forum.get(int(id))
condition = Topic.c.forum == int(id)
order_by = [Topic.c.sticky.desc(), Topic.c.last_reply_on.desc()]
if not forum.managers.has(request.user):
condition = (Topic.c.hidden == False) & condition
filter = request.GET.get("filter", "all")
if filter == "essence":
condition = (Topic.c.essence == True) & condition
elif filter == "sticky":
condition = (Topic.c.sticky == True) & condition
term = request.GET.get("term", "")
type = request.GET.get("type", "1")
if term:
if type == "1": # 查找主題
condition = (Topic.c.subject.like("%" + term + "%")) & condition
elif type == "2": # 查找用戶名
condition = (
and_(
Topic.c.posted_by == User.c.id,
User.c.username.like("%" + term + "%") | User.c.nickname.like("%" + term + "%"),
)
& condition
)
def created_on(value, obj):
return value.strftime("%Y-%m-%d")
def last_reply_on(value, obj):
return timesince(value)
def subject(value, obj):
if obj.topic_type:
_type = u"[%s]" % obj.get_display_value("topic_type")
else:
_type = ""
s = ""
if obj.sticky:
s += u'<font color="red">[頂]</font>'
if obj.hidden:
s += u'<font color="red">[隱]</font>'
if obj.closed:
s += u'<font color="red">[關]</font>'
if obj.essence:
s += u'<font color="red">[精]</font>'
if obj.homepage:
s += u'<font color="red">[首]</font>'
return _type + '<a href="/forum/%d/%d">%s</a>' % (int(id), obj.id, obj.subject) + s
fields_convert_map = {"created_on": created_on, "subject": subject, "last_reply_on": last_reply_on}
view = ListView(
Topic,
condition=condition,
order_by=order_by,
rows_per_page=rows_per_page,
pageno=pageno,
fields_convert_map=fields_convert_map,
)
view.query() # in order to get the total count
objects = view.objects()
pages = int(math.ceil(1.0 * view.total / rows_per_page))
return {
"forum": forum,
"objects": objects,
"filter": filter,
"term": term,
"page": pageno + 1,
"total": view.total,
"pages": pages,
"pagination": functions.create_pagination(request.url, view.total, pageno + 1, rows_per_page),
"type": type,
"filter_name": dict(settings.get_var("PARA/FILTERS")).get(filter),
}