zoukankan      html  css  js  c++  java
  • Python3.4 + Django1.7.7 搭建简单的表单并提交



    后面还有一个问题,是我把txt生成了,但是网页没有返回我还不知道,现在怎么直接返回txt并且展示出来txt 的内容,希望大牛不吝赐教


    首先有一个问题

    django1.7之前,这样用:


    HttpResponse(simplejson.dumps({“status”: ‘200’, “message”:u’登录成功’}), mimetype=’application/json’)


    没问题,但是django1,7之后就报错了,查了下问题发现应该这样用:


    HttpResponse(simplejson.dumps({“status”: ‘200’, “message”:u’登录成功’}), content_type=’application/json’)


    html模版:

    <html>
    <style type="text/css">
        {# <ul class="errorlist">。。。</ul> #}
        {# ul标签下的class="errorlist"的属性进行渲染 #}{# 标签下的属性 #}
        ul.errorlist {
            margin: 0;
            padding: 0;
        }
        {# <ul class="errorlist"><li>单词个数低于4个!</li></ul> #}
        {# errorlist class下的 li标签内的元素进行渲染 #}{# 属性下一级的标签 #}
        .errorlist li {
            background-color: red;
            color: white;
            display: block;
            font-size: 10px;
            margin: 0 0 3px;
            padding: 4px 5px;
        }
        .field{
            background-color:#BCD8F5;
        }
    </style>
    <head>
        <title>Contact us</title>
    </head>
    <body>
    
        {% if form.errors %}
            <p style="color: red;">
                Please correct the error{{ form.errors|pluralize }} below.
            </p>
        {% endif %}
    
        <form action="" method="post">
            <div class="field">
    		This is a brief description of Interim Fix :
                {# 自动生成的默认错误信息显示 #}
                {# 会被翻译成:<ul class="errorlist"><li>这个字段是必填项。</li></ul> #}
                {{ form.subject.errors }}
                <label for="id_subject">12</label>
                {{ form.subject }}
                {# 自定义的错误信息显示 #}
                {% if form.subject.errors%}
                <label for="id_self_def_error_info" style="color: red;">
                    *自定义错误信息:主题不能为空
                </label>
                {% endif %}
    
            </div>
            <div class="field">
                {{ form.email.errors }}
                <label for="id_email"> for IBM SPSS Data Collection DDL 7 ("Software").</label>
                {{ form.email }}
            </div>
            <div class="field">
                {{ form.message.errors }}
                <label for="id_message">页面中自定义的信息:</label>
                {{ form.message }}
            </div>
            <input type="submit" value="提交">
        </form>
    </body>
    </html>



    form.py

    #coding: gb2312
    from django import forms
    
    class ContactForm(forms.Form):
        subject = forms.CharField(max_length=10,label='subject')#设置最大长度为10
        email = forms.EmailField(required=False,label='Email')#非必要字段
        message = forms.CharField(widget=forms.Textarea,label='message')#指定form中组件的类型
    
        #自定义校验规则,该方法在校验时被系统自动调用,次序在“字段约束”之后
        def clean_message(self):
            message = self.cleaned_data['message']#能到此处说明数据符合“字段约束”要求
            num_words = len(message.split())
            if num_words < 0:#单词个数
                raise forms.ValidationError("your word is too short!")
            return message



    views.py


    #coding: gb2312
    from django.http import HttpResponse
    import datetime,calendar
    import time
    from django.http import HttpResponse
    from django.template import Context
    from django.template.loader import get_template
    from django.http import HttpResponse, Http404
    from django.contrib.auth.models import User
    from django.shortcuts import render_to_response
    from django.http import HttpResponseRedirect
    from django.contrib.auth import logout
    from django.template import RequestContext
    #from django import form
    
    from django.shortcuts import render 
    from .forms import ContactForm 
    #from django.shortcuts import render_to_response
    #from django_manage_app.forms import ContactForm
    
    def current_datetime(request):
        now = time.strftime('%Y-%m-%d-%H-%M-%S',time.localtime(time.time()))
        html = '<html><body>It is now %s.</body></html>' %now
        return HttpResponse(html)
        
    def contact_author(request):
        if request.method == 'POST':#提交请求时才会访问这一段,首次访问页面时不会执行
            form = ContactForm(request.POST)
            if form.is_valid():#说明各个字段的输入值都符合要求
                cd = form.cleaned_data#只有各个字段都符合要求时才有对应的cleaned_data
                #print (form.cleaned_data())
                print (cd['subject'])
                print (cd['email'])
                print (cd['message'])
                return HttpResponseRedirect('/thanks/')
            else:#有部分字段不符合要求,会有error相关信息给加到form中去,需要覆盖掉
                #print (form)
                print ('The data does not meet the requirements')
                print (form['subject'].errors)
                print (form['email'].errors)
                print (form['message'].errors)
        else:#首次访问该url时没有post任何表单
            form = ContactForm()#第一次生成的form里面内容的格式
            print (form)
            print (form.is_valid())
    
        #“首次访问”和“提交的信息不符合要求”时被调用
        return render_to_response('contact_author.html', {'form': form})
    
    
    def thanks(request):
    
        return render_to_response('thanks.html')
        
        
    def download_file(request):   
        #from django.http import HttpResponse          
        ## CSV  
        #import csv      
        #response = HttpResponse(mimetype='text/csv')  
        #response['Content-Disposition'] = 'attachment; filename=my.csv'  
        #writer = csv.writer(response)  
        #writer.writerow(['First row', 'Foo', 'Bar', 'Baz'])  
        #writer.writerow(['Second row', 'A', 'B', 'C', '"Testing"', "Here's a quote"])  
     
        # Text file  #要是返回txt放开这部分代码 return response
        #response = HttpResponse(content_type="text/plain")                                   
        #response['Content-Disposition'] = 'attachment; filename=my.txt'                
        #response.write("aa/n")  
        #response.write("bb")   
         
        # PDF file   
        #http://code.djangoproject.com/svn/django/branches/0.95-bugfixes/docs/outputting_pdf.txt  
        #from reportlab.pdfgen import canvas  #need pip install reportlab
        #response = HttpResponse()#)mimetype='application/pdf')  
        #response['Content-Disposition'] = 'attachment; filename=somefilename.pdf'  
        #p = canvas.Canvas(response)  
        #p.drawString(100, 100, "Hello world.")  
        #p.showPage()  
        #p.save()  
        #response = HttpResponse()
        fout=open("mysite//test.txt","wt") 
        str = "hello world"
        fout.write(str)
        fout.close()     
        #response['Content-Disposition'] = 'attachment; filename=test.txt' 
        data = open("mysite//test.txt", "rb").read()
    
        html = '<html><body>%s</body></html>' %str
        return HttpResponse(data, content_type="text/plain")
        
    

     参考文献:


    http://blog.chedushi.com/archives/7538



    
    
  • 相关阅读:
    sqlserver tips
    mysql tips
    小知识点集锦
    设计模式
    将微博或者qq空间的说说同步至博客园 wcf+js(ajax)跨域请求(1)
    WCF服务寄宿IIS与Windows服务
    C# 基础小知识之yield 关键字
    WPF命令绑定 自定义命令
    KnockOut 绑定之foreach绑定(mvc+knockout)
    P5019 铺设道路
  • 原文地址:https://www.cnblogs.com/wangyaning/p/7854008.html
Copyright © 2011-2022 走看看