根据廖雪峰的python教程和flask官方文档,自己写了个练手的小项目,中间出现了一些小问题,通过博客记录下,我认为学习一门新语言或者框架,最好的方式就是自己做一个demo,这个demo最好涉及整个开发流程,然后熟悉了整个流程了,然后针对流程的每个细节去重点学习。效率会高很多。
Python Flask代码实例
from flask import Flask
app = Flask(__name__)
app.route('url')
def index():
return 'Hello Python'
if __name__ == '__main__'
app.run()
main.py
namepaire.py
bloodpaire.py
xzpaire.py
static:存放网页中用到的JS,Css,图片等静态文件
py:三个类分别负责对姓名配对,血型配对,星座配对的处理
template:用来放置前端模板(falsk通过jinjia进行前端的渲染)
(关于文件目录的问题,在前端模板中调用css文件)
../static/css/amazeui.css
下面针对每个单元的代码进行解释
姓名配对处理
关于这个姓名配对,我用的是第一星座网的姓名配对,通过urllib2模拟它的操作,然后对返回的结果页通过HTMLParser结合正则表达式进行标签的分析,得到结果。
import re
import urllib2
from HTMLParser import HTMLParser
#继承HTMLParser实现对返回网页的结果解析
class MyHTMLParser(HTMLParser):
def __init__(self):
HTMLParser.__init__(self)
self.tagname=0
self.infolist=[]
def handle_starttag(self, tag, attrs):
if tag=='p':
self.tagname = tag
def handle_endtag(self, tag):
if tag=='b' and self.tagname=='p':
self.tagname='p'
else:
self.tagname=None
def handle_data(self, data):
if self.tagname=='p':
self.infolist.append(data)
class namePaire:
def __init__(self):
pass
def getresult(self,man,woman):
parser = MyHTMLParser()
urlstr='http://www.d1xz.net/sm/xingming_peidui.aspx?a1='+man+'&a2='+woman+''
try:
response=urllib2.urlopen(urlstr)
except urllib2.URLError, e:
if hasattr(e, 'code'):
print 'The server couldn\'t fulfill the request.'
print 'Error code: ', e.code
elif hasattr(e, 'reason'):
print 'We failed to reach a server.'
print 'Reason: ', e.reason
else:
doc=response.read()
page=doc.decode("gbk")
try :
parser.feed(page)
except :
pass
finally:
list = parser.infolist[1:-1]
parser.close()
print list
return list
(后面博客将会对urllib2,HTMLParser做详细学习)
前端模板
{%extends "base.html" %}
{%block namecontent%}
<p class="am-kai" style="color:#FF88C2"><b>姓名究竟赋予了我们一生什么样的命运,两个人的姓名又会擦出什么样的火花呢?在下方输入配对双方的姓名,即可测算出两人的关系哦。准得有点儿邪哦,快来试试吧。(不可以此做为恋爱的依据哦)b>p>
<form action="/name" method="post">
<div class="am-form-group">
<label for="man-name" style="color:#FF88C2">男label>
<input type="text" class="" id="man-name" name="man" placeholder="输入姓名(汉字)">
div>
<div class="am-form-group">
<label for="woman-name" style="color:#FF88C2">女label>
<input type="text" class="" id="woman-name" name="woman"placeholder="输入姓名(汉字)">
div>
<div class="am-form-group">
<input type="submit" class="am-btn am-btn-default am-round" style="background-color:#FF88C2;color:#FFFFFF"value="缘分测试">
div>
form>
{%if list.__len__()!=0%}
<h2 style="color:#FF88C2">{{man}}&&{{woman}}h2>
<h3 style="color:#FF88C2"><b>{{list[0]}}{{list[1]}}b>h3>
{%endif%}
{%endblock%}
涉及的内容是如何在前端中使用后端的数据,然后进行相应页面的渲染
from flask import Flask,render_template,request
from namepaire import namePaire
app = Flask(__name__)
app.route('/name',methods=['POST','GET'])
def delname():
if request.method == 'POST':
namedel = namePaire()
return ('nametest.html',list = namedel.getresult(request.form['man']),request.form['woman'])
else:
return ('nametest.html')
if __name__ == __main__:
app.run()
当我们通过app.run()的时候,当我们对网页中的内容做了修改之后,我们需要重启服务器才能够看到我们修改的结果,同时和我们在同一个网络下的其它用户是无法访问的.
app.run(host='0,0,0,0')
app.debug=True
这部分涉及到flask的相关问题,这个在后面也会给出详细学习,还有jinjia的渲染方面的问题。
WEB全栈小菜的大致一个学习流程就出来了
然后是对Python的学习
接下来的博客将对这几个方面进行相关的学习