设为首页 收藏本站
查看: 959|回复: 0

[经验分享] 从零开始学Python-day8

[复制链接]

尚未签到

发表于 2018-8-16 06:28:01 | 显示全部楼层 |阅读模式
##flask逻辑端代码  
[root@test blog]# cat demo.py
  
#!/usr/bin/python
  
#coding:utf-8
  

  
from flask import Flask ,render_template,redirect,request
  
import MySQLdb as mysql
  
from datetime import datetime
  

  
datas = mysql.connect(user='root',passwd='123456',db='reboot',charset='utf8')
  
datas.autocommit(True)
  
cur = datas.cursor()
  

  

  
fields = ["id","name","name_cn","password","email","mobile","role","status","create_time"]
  

  
app = Flask(__name__)
  

  
def getNow():
  now = datetime.now().strptime("%Y-%m-%d %H:%M:%S")
  return now
  

  
@app.route('/user/userlist')
  
def userlist():
  sql = "select %s from %s" %(','.join(fields),'users')
  cur.execute(sql)
  res = cur.fetchall()
  users = [ dict((v,row[k]) for k ,v in enumerate(fields)) for row in res]
  return render_template('userlist.html',users = users)
  

  
@app.route('/user/delete')
  
def delete():
  id = request.args.get('id',None)
  print id
  d_sql = "No id error"
  if id :
  d_sql = "DELETE from users where id = %s" %  id
  cur.execute(d_sql)
  return redirect('/user/userlist')
  return render_template('test.html',errmes = d_sql)
  

  
@app.route('/user/update',methods=['GET','POST'])
  
def update():
  if request.method == "POST":
  user = dict(request.form)
  user = dict((k,v[0]) for k ,v in user.items())
  #print user ==>{'mobile': u'CCC', 'name_cn': u'ccccccc', 'id': u'2', 'name': u'cc', 'email': u'CC@chinacache.com'}
  #user.pop('id')
  tmp_list = [ "%s='%s'"%(k,v) for k,v  in user.items() if k != "id"]
  #print tmp_list
  update_sql = "UPDATE users set %s  where id=%s" %(','.join(tmp_list),user['id'])
  cur.execute(update_sql)
  return redirect('/user/userlist')
  else:
  id = request.args.get('id',None)
  print id
  select_sql = "No id error"
  if id :
  select_sql = "select %s from users  where id = %s" %(','.join(fields),id)
  print select_sql
  cur.execute(select_sql)
  res = cur.fetchone()
  #print res ==>(2L, u'cc', u'cc', u'cC23 ', u'CC@chinacache.com', u'CCC', u'user', 0, datetime.datetime(2016, 11, 30, 16, 4, 33))
  user = dict((v,res[k]) for k ,v in enumerate(fields))
  #return redirect('/user/userlist')
  return render_template('userinfo.html',user = user)
  

  

  
if __name__ == "__main__":
  app.run(host='0.0.0.0',port=888,debug=True)
  
[root@test blog]#
  

  
##前端html代码
  
[root@test blog]# cat templates/userlist.html
  
<html>
  
<p>userlist</p>
  
<table border='1px'>
  <thead>
  <tr><th>Name</th>
  <th>Name_CN</th>
  <th>Email</th>
  <th>Mobile</th>
  <th>Role</th>
  <th>Status</th>
  <th>Create_Time</th>
  <th>Operate></th></tr>
  </thead>
  <tbody>
  {% for user in users %}
  <tr><input type='hidden' name='id' value={{ user.id }}><td>{{ user.name}}</td>
  <td>`user`.`name_cn`</td>
  <td>`user`.`email`</td>
  <td>`user`.`mobile`</td>
  <td>`user`.`role`</td>
  <td>`user`.`status`</td>
  <td>`user`.`create_time`</td>
  <td><a href='/user/update?id=`user`.`id`'>更新</a>  <a href='/user/delete?id=`user`.`id`'>删除</a></tr>
  {% endfor %}
  </tbody>
  
</table>
  
</html>
  
[root@test blog]#
  
[root@test blog]# cat templates/userinfo.html
  
<html>
  
<p>userinfo</p>
  
<form action="/user/update" method="POST">
  <table>
  
    <tr>
  <td><input type="hidden" name='id' value=`user`.`id` ></td>
  
    </tr>
  
    <tr>
  <td>Name<input type='text' name='name' value=`user`.`name`></td>
  
    </tr>
  
    <tr>
  
    <td>Name_CN<input type='text' name='name_cn' value =`user`.`name_cn`></td>
  
    </tr>
  
    <tr>
  
    <td>Email<input type='text' name='email' value=`user`.`email`></td>
  
    </tr>
  
    <tr>
  
    <td>Mobile<input type='text' name='mobile' value=`user`.`mobile`></td>
  
    </tr>
  
    <tr>
  
    <td>Role<select >
  {% if user.role == "admin" %}
  <option value = 'admin'>管理员</option>
  {% elif user.role == "sa" %}
  <option value = 'sa'>运 维</option>
  {% else %}
  <option value = 'user'>普通用户</option>
  {% endif %}
  </select>
  </td>
  
    </tr>
  
    <tr>
  
    <td>status<select >
  {% if user.status == 0 %}
  <option value = 0>正常</option>
  {% else %}
  <option value = 1>锁定</option>
  {% endif %}
  </select>
  
    </tr>
  <tr><input type="submit" value='确认修改'></td></tr>
  
</form>
  
</html>
  
[root@test blog]#

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-552341-1-1.html 上篇帖子: 面向对象 Python的类 介绍 下篇帖子: Python 学习笔记
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表