Python Flask 初體驗(緣分匹配小項目)
根據廖雪峯的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()
- 運行這個實例我們就可以再本地瀏覽器上看到Hello Python
- 項目文件結構
- static
- js
:fonts
:css - template
- base.html
- footer.html
- nametest.html
- xxtest.html
- xztest.html
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的學習
接下來的博客將對這幾個方面進行相關的學習