Python web框架flask的开发

2017-12-21  本文已影响0人  Mr内涵

在windows10下搭建Python3的开发环境:

1.下载Anaconda3,下载地址百度,根据自己的windows环境下载32-bit或者64-bit

2.安装Anaconda3,选择完安装路径之后,在第二步骤的时候,有两个选项:如图

第一个选项是添加系统path环境变量,第二个将Python3.6作为idea的默认开发环境,两个都打勾。

3.安装完成之后配置pycharm的环境,如图:

3.配置好之后在cmd输入Python之后,如图,表示python的环境配置成功:

下面就可以开发Python了。

关于Python3.6与Anaconda3的区别自行百度

4.flask是Python开发的web框架,与Java的spring框架是一个道理。如何使用flask,它的api:

    http://docs.jinkan.org/docs/flask/

下面是一个简单的flask的web程序

server.py

from gevent.wsgi import WSGIServer

from tornado.httpserver import HTTPServer

from SnowNLP_JS import app(这段代码是引入了SnowNLP_JS.py 作为一个app的变量)

http_server = WSGIServer(('127.0.0.1', 5000), app)

http_server.serve_forever()

SnowNLP_JS.py

# -*- coding: utf-8 -*-

from snownlp import SnowNLP

import json

from flask import Flask, render_template, request, jsonify,Response

app = Flask(__name__)

# @app.route('/')

@app.route('/getfunc', methods=['POST', 'GET'])

def getfunc():

#data = json.loads(request.form.get('data'))

# resp = Response(data)

#Response.headers['Access-Control-Allow-Origin'] = '*'

# data = json.loads(request.get_json())

# story_data = json.loads(request.get_data().decode('utf-8'))

#context = data['lesson']

jsonp_callback = request.args.get('callback', 'jsonpCallback1')

context = request.values['content']

print(context)

s = SnowNLP(context)

'''

s = SnowNLP("是不是还不是就这样子了,完全不行,我觉得这车完全不行!")

'''

arry = []

'''' for sentence in s.sentences:

#print(sentence)

'''

'''

s0 = SnowNLP(s.sentences[0])

s1 = SnowNLP(s.sentences[1])

s2 = SnowNLP(s.sentences[2])

s3 = SnowNLP(s.sentences[3])

s4 = SnowNLP(s.sentences[4])

'''

_snownlpNum = 0

for k in s.sentences:

print(k)

_snownlpvalue = SnowNLP(k)

print(_snownlpvalue.sentiments)

arry.insert(_snownlpNum, _snownlpvalue.sentiments)

_snownlpNum + 1

'''

print(s0.sentiments)

print(s1.sentiments)

print(s2.sentiments)

print(s3.sentiments)

print(s4.sentiments)

arry.insert(0,s0.sentiments)

arry.insert(1,s1.sentiments)

arry.insert(2,s2.sentiments)

arry.insert(3,s3.sentiments)

arry.insert(4,s4.sentiments)

print(arry)

s2 = SnowNLP(sentence[1])

print("s2:"+s2.sentiments)

'''

positive = []

negative = []

value = 0

value1 = 0

num = 0

for i in arry:

# print(i)

if (i < 0.5):

print("负面词:" + str(i))

value += i

positive.insert(num, i)

num + 1

elif (i > 0.5):

print("正面词:" + str(i))

value1 += i

negative.insert(num, i)

num + 1

# ("负面词结果:" + str(value / 2))

# print("正面词结果:" + str(value1 / 3))

# print("正面词结果1:" + str((0.8342 + 0.8584 + 0.6251) / 3))

# print("负面词结果1:" + str((0.3280 + 0.3281) / 2))

print(negative)

print(positive.__len__())

print(positive)

# _result_positive = 0

# np.positive()

_result_positive = sum(positive)

_result_negative = sum(negative)

'''

print(_result_positive/positive.__len__())

print(_result_negative/negative.__len__())

print(_result_positive)

print(_result_negative)

'''

print(_result_positive / (_result_positive + _result_negative))

print(_result_negative / (_result_positive + _result_negative))

'''

_data_result1 = [{"_result_positive": _result_positive / (_result_positive + _result_negative),

"_result_negative": _result_negative / (_result_positive + _result_negative)},

{"_result_positive_len": positive.__len__(),

"_result_negative_len": negative.__len__()}]

_data_result = {"_result_positive":_result_positive/(_result_positive+_result_negative),"_result_negative":_result_negative/(_result_positive+_result_negative)}

'''

jsondate = {'_result_positive':_result_positive / (_result_positive + _result_negative),

'_result_negative':_result_negative / (_result_positive + _result_negative),

'_result_positive_len':positive.__len__(),

'_result_negative_len':negative.__len__()}

return Response(

"%s(%s);" % (jsonp_callback, json.dumps({'ok': True, 'data': jsondate})),

mimetype="text/javascript"

)

# return jsondate

#print(getfunc())

'''

@app.route('/testajax')

def testAjax(request):

func = request.GET.get('callback')

content = '%s(100000)' % (func,)

return HttpResponse(content)

@app.route('/demo', methods=['POST'])

def home():

data = json.loads(request.form.get('data'))

result_json = json.dumps(data)

# Response

resp = Response(result_json)

resp.headers['Access-Control-Allow-Origin'] = '*'

return resp

def request_ajax_url(url, body, referer=None, cookie=None, **headers):

import urllib

req = urllib2.Request(url)

req.add_header('Content-Type', 'application/json')

req.add_header('X-Requested-With','XMLHttpRequest')

if cookie:

req.add_header('Cookie', cookie)

if referer:

req.add_header('Referer', referer)

if headers:

for k in headers.keys():

req.add_header(k, headers[k])

postBody = json.dumps(body)

response = urllib2.urlopen(req, postBody)

if response:

return response

@app.route('/run')

def run():

import time

"use username:xfkxfk; use password:123456"

login_url = 'http://www.xx.com/member/Login.aspx'

login_body = {"action":"login","UserName":"xfkxfk","Password":"123456","AutomaticLogin":False}

login_referer = "http://www.xx.com/member/Login.aspx?ReturnUrl=aHR0cDovL3d3dy5sdXNlbi5jb20vRGVmYXVsdC5hc3B4"

url = 'http://www.xx.com/Member/MobileValidate.aspx'

referer = "http://www.xx.com/Member/ModifyMobileValidate.aspx"

headers = {}

response = request_ajax_url(login_url, login_body, login_referer)

if response.read() == "1":

print(" Login Success !!!")

if response.headers.has_key('set-cookie'):

set_cookie = response.headers['set-cookie']

else :

print (" Get set-cookie Failed !!! May Send Messages Failed ~~~")

if len(sys.argv) < 3:

print ("\nUsage: python " + sys.argv[0] + "mobile_number" + "count\n")

sys.exit()

mobile_number = sys.argv[1]

count = sys.argv[2]

body = {"action":"GetValidateCode","Mobile":mobile_number}

i=0

while i < int(count):

response = request_ajax_url(url,body,referer,set_cookie)

i= i+1

if response.read() == "发送成功":

print(" Send " + count + " Messages To " + mobile_number + " !!!")

def test():

import json

from flask import jsonify, Response, json

data = []  # or others

return jsonify(ok=True, data=data)

jsonp_callback = request.args.get('callback', '')

if jsonp_callback:

return Response(

"%s(%s);" % (jsonp_callback, json.dumps({'ok': True, 'data': data})),

mimetype="text/javascript"

)

return ok_jsonify(data)

'''

if __name__ == "__main__":

app.run()

以上的方法实现了情感词分析的功能。同时实现了跨域的问题。

5.请求方式

http://127.0.0.1:5000/getfunc

参数:json格式的数据,{content:"你好!"}

6.如果出现模块不存在后者是未定义的错误,需要安装该模块,命令:

pip install 模块名

上一篇 下一篇

猜你喜欢

热点阅读