首页>>后端>>Python->django什么情况下总for(2023年最新解答)

django什么情况下总for(2023年最新解答)

时间:2023-12-09 本站 点击:0

导读:本篇文章首席CTO笔记来给大家介绍有关django什么情况下总for的相关内容,希望对大家有所帮助,一起来看看吧。

django html页面两层for循环,里层for循环把外层for循环的值作为参数报错。

jsp页面判断循环了几次只能用变量记录,比如用index这个参数来做累计。

c:forEach标签的语法定义如下所示。

c:forEach var="name" items="expression" varStatus="name"

begin="expression" end="expression" step="expression"

body content

/c:forEach

c:forEach标签具有以下一些属性:

var:迭代参数的名称。在迭代体中可以使用的变量的名称,用来表示每一个迭代变量。类型为String。

items:要进行迭代的集合。对于它所支持的类型将在下面进行讲解。

varStatus:迭代变量的名称,用来表示迭代的状态,可以访问到迭代自身的信息。

begin:如果指定了items,那么迭代就从items[begin]开始进行迭代;如果没有指定items,那么就从begin开始迭代。它的类型为整数。

end:如果指定了items,那么就在items

结语:以上就是首席CTO笔记为大家整理的关于django什么情况下总for的全部内容了,感谢您花时间阅读本站内容,希望对您有所帮助,更多关于django什么情况下总for的相关内容别忘了在本站进行查找喔。

结束迭代;如果没有指定items,那么就在end结束迭代。它的类型也为整数。

step:迭代的步长。

index:当前这次迭代从0开始的迭代索引。

django模块不能用for i in range(0, 5)总报错

我觉得你的目的很简单,就是想在模版中简单执行5次循环。可以使用make_list过滤器:

{% for i in '12345'|make_list %}

    {{ i }} 

{% endfor %}

如果觉得这样有局限性,可以写一个简单的自定义过滤器:

@register.filter('list')

def do_list(value):

    return range(1, value+1)

然后这样使用:

{% for i in 5|list %}

    {{ i }}

{% endfor %}

如果你已经在视图中定义了好了一个变量,而只想执行5次,那么可以这样子:

{% for i in example|slice:":5" %}

    {{ i }}

{% endfor %}

Django什么情况

在朋友和同事的极力推荐下最近开始看上了python,其实主要是还是因为python是2007年度语言,怎么的也要与时俱进呀.最近一路看来有些心得,希望能与大家分享,小弟其实也只接触不到一周的python,有说错的地方还望大家指出改正.

不打算从py的语法基础说起了,直接说说对django的心得:

接触django首先需要了解可能就是他那个model,建立一个model就什么都有了,这对于搞java得人员来说还是挺有吸引力的(当然貌似对于动态语言这都是小儿科),那么让我们先看一个model的例子:

偷懒了,直接拿django-admin里面的User出来了

class User(models.Model):

username = models.CharField(_('username'), maxlength=30, unique=True, validator_list=[validators.isAlphaNumeric]))

first_name = models.CharField(_('first name'), maxlength=30, blank=True)

last_name = models.CharField(_('last name'), maxlength=30, blank=True)

email = models.EmailField(_('e-mail address'), blank=True)

password = models.CharField(_('password'), maxlength=128))

class Meta:

ordering = ('username',)

每个属性就是一个库表的字段,定义起来非常简单明了,models里面提供了很多种类的Field类似上面的EmailField。不同的Field有不同的设置,可以看相应的原来来了解相关的设置.

在model class内部还有一个class Meta,这个Class的属性制定了这个表的一些存取策略,例如这里的ordering。MetaClass里面的属性可以用model的_meta属性取得。OK,那么这样一个model怎么就能实现对数据库表的灵活操作了呢。让我们来看看吧。

首先先分析一下/django/django/db/models/base.py这个文件,其中包含了models.Model这类的定义:

看看class定义的第一行吧,第一行就够我琢磨一阵子的了:

class Model(object):

__metaclass__ = ModelBase

Model采用了new style class定义,关于这个内容大家可以放狗看一下,第一行是一个__metaclass__属性的定义,该属性的值是ModelBase,这是一个类。__metaclass__的意思是,指定一个class,这个class的实例就是本class,相信您已经晕了。那么就拿这个Model的例子来说明一下,如果没有__metaclass__这个属性,产生一个实例就是正常的流程,有了这个属性流程会有改变:

首先调用BaseModel.__new__(cls, name, bases, attrs)这个方法,回返回的值是一个class类型,然后用这个class来创建实例。其实BaseModel就是Model的元类,来制定Model这个类的最终样子。关于元类的更多信息请看这里

那么我们的目光一下转移到BaseModel这个类上,我有种直觉,Meta这个class最后可以用_meta来取就是在这里做的手脚,看一下BaseModel的定义吧,有点长:

class ModelBase(type):

"Metaclass for all models"

def __new__(cls, name, bases, attrs):

# If this isn't a subclass of Model, don't do anything special.

if name == 'Model' or not filter(lambda b: issubclass(b, Model), bases): #1

return super(ModelBase, cls).__new__(cls, name, bases, attrs)

# Create the class.

new_class = type.__new__(cls, name, bases, {'__module__': attrs.pop('__module__')}) #2

new_class.add_to_class('_meta', Options(attrs.pop('Meta', None))) #3

new_class.add_to_class('DoesNotExist', types.ClassType('DoesNotExist', (ObjectDoesNotExist,), {}))

# Build complete list of parents #4

for base in bases:

# TODO: Checking for the presence of '_meta' is hackish.

if '_meta' in dir(base):

new_class._meta.parents.append(base)

new_class._meta.parents.extend(base._meta.parents)

model_module = sys.modules[new_class.__module__]

if getattr(new_class._meta, 'app_label', None) is None:

# Figure out the app_label by looking one level up.

# For 'django.contrib.sites.models', this would be 'sites'.

new_class._meta.app_label = model_module.__name__.split('.')[-2] #5

# Bail out early if we have already created this class.

m = get_model(new_class._meta.app_label, name, False) #6

if m is not None:

return m

# Add all attributes to the class.

for obj_name, obj in attrs.items():

new_class.add_to_class(obj_name, obj) #7

# Add Fields inherited from parents

for parent in new_class._meta.parents:

for field in parent._meta.fields:

# Only add parent fields if they aren't defined for this class.

try:

new_class._meta.get_field(field.name)

except FieldDoesNotExist:

field.contribute_to_class(new_class, field.name) #8

new_class._prepare()

register_models(new_class._meta.app_label, new_class) #9

# Because of the way imports happen (recursively), we may or may not be

# the first class for this model to register with the framework. There

# should only be one class for each model, so we must always return the

# registered version.

return get_model(new_class._meta.app_label, name, False) #10

简单分析一下这个代码:

1. 检查class是否为Model的子类,不是的话,不做任何处理,直接传给父类处理,也就相当于正常的处理了class,注意super在多重继承的时候应该严格使用

2. 用type来创建类,创建的就是正常的ModelClass

3. 这句很重要,add_to_class是Model里面的class方法,这个方法其实就是传入name和value,给Model添加class属性.看到了,原来神奇的_meta就是这么来的. 提到add_to_class方法,简单看一下它的代码:

def add_to_class(cls, name, value):

if name == 'Admin':

assert type(value) == types.ClassType, "%r attribute of %s model must be a class, not a %s object" % (name, cls.__name__, type(value))

value = AdminOptions(**dict([(k, v) for k, v in value.__dict__.items() if not k.startswith('_')]))

if hasattr(value, 'contribute_to_class'):

value.contribute_to_class(cls, name)

else:

setattr(cls, name, value)

add_to_class = classmethod(add_to_class)

最后一句是制定这个方法是class方法,特点就是方法的第一个参数是本class,其实classmethod就是一个装饰器,在2。4之后可以使用@来简写。这里不得不提的是他对Admin的特殊处理,虽然AdminOption不是在admin模块里面的,但是这么做还是跟一个Admin的东东绑定起来了,在java的世界解耦是一件大事,看到下面还有对'contribute_to_class'这个方法的特殊处理,django为啥不弄的解耦点呢。而且同样是包装成Option,一个是在BaseModel里面弄(那个Meta的包装),一个在add_to_class方法里面弄,实在有点不优雅,可能还没了解太多,不知道他的深度用意吧。

4. Meta的集成,Option的这个类提供继承方法

5. 取得applabel,就是把model的名字分割取到数第二个,我很喜欢-2这样的设定

6. get_model方法取得缓存里面的东西。

7. 把所有的class attr拿出来搞一遍,一般的属性就setattr弄回去了,要是这个属性有contribute_to_class这个callable属性,那就执行之(Admin的处理完全也可以这样,其实我们常用的objects就是用这个方法弄的)

8. 每个Field调用自己的contribute_to_class方法来进行特殊的处理

9. 进入缓存,,暂且叫缓存吧,里面的东西大家看看很简单 文件在 /django/django/db/models/loading.py 里面还是有很多内容的

10.看注释说的很清楚了,我们一定要在缓存里面拿model。

django for循环怎么中途退出

Django不支持退出循环操作。如果我们想退出循环,可以改变正在迭代的变量,让其仅仅包含需要迭代的项目。同

理,Django也不支持continue语句,我们无法让当前迭代操作跳回到循环头部。(请参看本章稍后的理念和限制小节,了解下

决定这个设计的背后原因)

{% for %} 标签在循环中设置了一个特殊的 forloop 模板变量。这个变量能提供一些当前循环进展的信息:

forloop.counter 总是一个表示当前循环的执行次数的整数计数器。这个计数器是从1开始的,

所以在第一次循环时forloop.counter 将会被设置为1。例子如下:

{% for item in todo_list %}

p{{ forloop.counter }}: {{ item }}/p

{% endfor %}

django 怎么控制for循环的次数

1、从后台传数据到html的时候就只传需要显示的页数(比如,以一个列表[1,2,3,4,.....]),然后在html for循环 2、把全部页数都传到前台,列出来,然后用js控制哪些显示,哪些隐藏。

Django for 循环

你在传入键值对'TutorialList':list的时候只传入一个元素的list就行了。在视图函数中对list先预处理。

结语:以上就是首席CTO笔记为大家整理的关于django什么情况下总for的全部内容了,感谢您花时间阅读本站内容,希望对您有所帮助,更多关于django什么情况下总for的相关内容别忘了在本站进行查找喔。


本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:/Python/20741.html