万法同源

一直觉得可能自己不太适合搞技术,更适合在天桥底下支个摊子说书。技术的东西从来没人关注,扯东扯西的文章莫名的火。之前的一篇文章MarkDown添加图片的三种方式不管是在技术为主的CSDN还是娱乐为主的简书,都莫名的火爆,看图:

其实文章没什么含量,就是介绍了下markdown添加图片的方式,唯一新奇的可能就是使用了base64的图片二进制转化。

![avatar]\(data:image/png;base64,iVBORw0......)

1、使用python将图片转化为base64字符串

  1. import base64
  2. f=open('723.png','rb') #二进制方式打开图文件
  3. ls_f=base64.b64encode(f.read()) #读取文件内容,转换为base64编码
  4. f.close()
  5. print(ls_f)

2、base64字符串转化为图片

  1. import base64
  2. bs='iVBORw0KGgoAAAANSUhEUg....' # 太长了省略
  3. imgdata=base64.b64decode(bs)
  4. file=open('2.jpg','wb')
  5. file.write(imgdata)
  6. file.close()

可我干嘛今天要说这事情呢?看标题喽…

前天我谢了一篇爬虫车标网,将数据存储的文章,里面涉及到了将图片进行二进制存储至数据库的操作。

通过**request.get(url).content**获取的二进制字符串,直接存储至SQLite数据库的BLOB字段中。如果我们需要显示图片,直接通过open函数的写入数据即可生成原始的图片。但是,如果我不想写入图片,而希望直接展示在web界面上呢?也可以通过markdown添加图片的方式,使用base64的编码来实现!

Flask展示图片例子

我们先不通过读取数据库,而是直接获取requests.get(url).content的方式测试Flask的图片展示。

HTML代码:

  1. <!DOCTYPE html>
  2. <html lang="en">
  3. <head>
  4. <meta charset="UTF-8">
  5. <title>Title</title>
  6. </head>
  7. <body>
  8. <img src="data:;base64,{{ img }}">
  9. </body>
  10. </html>

Flask后台代码:

  1. # -*- coding: utf-8 -*-
  2. # @Author : 王翔
  3. # @JianShu : 清风Python
  4. # @Date : 2019/7/24 0:25
  5. # @Software : PyCharm
  6. # @version :Python 3.7.3
  7. # @File : image_show.py
  8. from flask import Flask, render_template
  9. import base64
  10. import requests
  11. app = Flask(__name__)
  12. @app.route("/show")
  13. def show_image():
  14. r = requests.get('http://img.chebiaow.com/thumb/cb/allimg/1303/1-1303061Z600520,c_fill,h_138,w_160.jpg')
  15. image = base64.b64encode(r.content).decode('ascii')
  16. return render_template('index.html', img=image)
  17. if __name__ == '__main__':
  18. app.run()

图片展示OK,使用这种方式,我们就没必要将图片文件先从数据库中读取生成后,再通过url_for(‘static’,filename=‘x.png’)的方式进行显示了。

完善车标测试app

上次的爬虫文章爬取车标网图片与数据,以后不要说这什么车你不认识了!我们将获取车标网站的141中汽车品牌存储到了SQLite数据库中,结果如下:

那么今天,我们就把这些数据库信息配合Flask完成一个简单的车标学习简单网站吧,下来看看实现效果:

后台Flask代码:

  1. # -*- coding: utf-8 -*-
  2. # @Author : 王翔
  3. # @JianShu : 清风Python
  4. # @Date : 2019/7/25 1:37
  5. # @Software : PyCharm
  6. # @version :Python 3.7.3
  7. # @File : app.py
  8. from flask import Flask, render_template, g
  9. import sqlite3
  10. import random
  11. import base64
  12. app = Flask(__name__)
  13. DATABASE = 'static/db/car.db'
  14. app.secret_key = 'Breeze Python'
  15. def connect_db():
  16. return sqlite3.connect(DATABASE)
  17. @app.before_request
  18. def before_request():
  19. g.db = connect_db()
  20. @app.teardown_request
  21. def teardown_request(exception):
  22. if hasattr(g, 'db'):
  23. g.db.close()
  24. def query_db(query, args=()):
  25. cur = g.db.execute(query, args)
  26. rv = [dict((cur.description[idx][0], value)
  27. for idx, value in enumerate(row)) for row in cur.fetchall()]
  28. if not query.startswith('select'):
  29. g.db.commit()
  30. return rv[0] if rv else None
  31. @app.route('/car')
  32. @app.route('/')
  33. def index():
  34. id = random.randint(1, 141)
  35. car_info = query_db('select name,image,founded,models,website from car_logo where id={}'.format(id))
  36. car_info['image'] = base64.b64encode(car_info['image']).decode('ascii')
  37. print(car_info)
  38. return render_template('index.html', car=car_info)
  39. if __name__ == '__main__':
  40. app.run(host='0.0.0.0', port=7000)

前台HTML代码:

  1. <!DOCTYPE html>
  2. <html lang="en">
  3. <head>
  4. <meta charset="UTF-8">
  5. <meta http-equiv="X-UA-Compatible" content="IE=edge">
  6. <meta name="viewport" content="width=device-width, initial-scale=1 ,user-scalable=no">
  7. <title>清风python</title>
  8. <link rel="icon" href="{{ url_for('static',filename='favicon.ico') }}">
  9. <link rel="stylesheet" href="{{ url_for('static',filename='css/bootstrap.min.css') }}">
  10. <link rel="stylesheet" href="{{ url_for('static',filename='css/main.css') }}">
  11. <script src="{{ url_for('static',filename='js/jquery.min.js') }}"></script>
  12. </head>
  13. <body>
  14. <div class="container container-small">
  15. <div class="content">
  16. <div class="header">
  17. 车标学习
  18. </div>
  19. <div class="block-info">
  20. <div class="form-group" align="center">
  21. <p><img class="img-rounded" src="data:;base64,{{ car.image }}"></p>
  22. </div>
  23. <div class="form-group car-info">
  24. <table class="table table-hover table-bordered table_show table-condensed">
  25. <tbody>
  26. <tr>
  27. <th>品牌</th>
  28. <td id="idiom_name"> {{ car.Name }}</td>
  29. </tr>
  30. <tr>
  31. <th>始于</th>
  32. <td id="idiom_meaning">{{ car.founded }}</td>
  33. </tr>
  34. <tr>
  35. <th>车型</th>
  36. <td id="idiom_example"> {{ car.models }}</td>
  37. </tr>
  38. <tr>
  39. <th>官网</th>
  40. <td id="idiom_example"> {{ car.website }}</td>
  41. </tr>
  42. </tbody>
  43. </table>
  44. </div>
  45. <div class="form-group ">
  46. <a class="form-control btn-primary" href="{{ url_for('index') }}">换一个</a>
  47. </div>
  48. </div>
  49. </div>
  50. <div class="footer">
  51. ©2019-欢迎关注我的公众号:<a href="https://www.jianshu.com/u/d23fd5012bed">清风Python</a>
  52. </div>
  53. </div>
  54. </body>
  55. </html>

The End

OK,今天的内容就到这里,如果觉得内容对你有所帮助,欢迎点击文章右下角的“在看”。 公众号回复车标学习,下载整套代码及数据库信息。 期待你关注我的公众号清风Python,如果你觉得不错,希望能动动手指转发给你身边的朋友们。

来源:华为云社区征文 作者:清风Python

车标知识学习网页开发,与Flask通过base64展示二进制图片 #华为云·寻找黑马程序员#的更多相关文章

  1. Flask开发VIP版HttpServer #华为云·寻找黑马程序员#

    欢迎添加华为云小助手微信(微信号:HWCloud002 或 HWCloud003),输入关键字"加群",加入华为云线上技术讨论群:输入关键字"最新活动",获取华 ...

  2. 三伏天里小试牛刀andriod 开发 #华为云·寻找黑马程序员#

    2019年07月,北京,三伏天,好热啊.越热自己还越懒得动换(肉身给的信号),但是做为产品经理/交互设计师的,总想着思考些什么(灵魂上给的信号),或者是学习些什么,更有利于将来的职业发展吧,哈哈哈.工 ...

  3. 三伏天里小试牛刀andriod 开发 #华为云·寻找黑马程序员#【华为云技术分享】

    2019年07月,北京,三伏天,好热啊.越热自己还越懒得动换(肉身给的信号),但是做为产品经理/交互设计师的,总想着思考些什么(灵魂上给的信号),或者是学习些什么,更有利于将来的职业发展吧,哈哈哈.工 ...

  4. 使用Python开发小说下载器,不再为下载小说而发愁 #华为云·寻找黑马程序员#

    需求分析 免费的小说网比较多,我看的比较多的是笔趣阁.这个网站基本收费的章节刚更新,它就能同步更新,简直不要太叼.既然要批量下载小说,肯定要分析这个网站了- 在搜索栏输入地址后,发送post请求获取数 ...

  5. Python开发还在用virtualenv?不如了解下pipenv...#华为云·寻找黑马程序员#

    又见 Kenneth Reitz 之前公众号写了一篇文章爬虫新宠requests_html 带你甄别2019虚假大学,其中主要是为了介绍模块**requests_html,这个模块的作者还开发了req ...

  6. 移动端开发语言的未来的猜想#华为云&#183;寻找黑马程序员#【华为云技术分享】

    版权声明:本文为博主原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明. 本文链接:https://blog.csdn.net/devcloud/article/detai ...

  7. 2019年最新超级有趣好玩的html+css网页布局课程,前端入门基础,html5+css3零基础入门课程-黑马程序员pink老师精心录制

    大家好,我是黑马程序员pink老师!! 本次视频是前端零基础入门的课程,pink老师采取有趣好玩讲法,带你快乐的学习枯燥的html+css知识,学完之后让你能快速布局pc端页面.代码也可以讲的好玩有趣 ...

  8. 黑马程序员:轻松精通Java学习路线连载1-基础篇!

    编程语言Java,已经21岁了.从1995年诞生以来,就一直活跃于企业中,名企应用天猫,百度,知乎......都是Java语言编写,就连现在使用广泛的XMind也是Java编写的.Java应用的广泛已 ...

  9. 黑马程序员:3分钟带你读懂C/C++学习路线

    随着互联网及互联网+深入蓬勃的发展,经过40余年的时间洗礼,C/C++俨然已成为一门贵族语言,出色的性能使之成为高级语言中的性能王者.而在今天,它又扮演着什么样重要的角色呢?请往下看: 后端服务器,移 ...

随机推荐

  1. windows下离线安装mysql8.0服务(支持多个安装,端口不同就可以)

      1.官网下载 mysql文件.官网下载链接:https://dev.mysql.com/downloads/mysql/ 选择mysql下载的系统版本. 此处可以下载MSI安装包,图简单的朋友可以 ...

  2. 在vue中如何使用axios

    1.前言 在Vue1.0的时候有一个官方推荐的 ajax 插件 vue-resource,但是自从 Vue 更新到 2.0 之后,官方就不再更新 vue-resource. 关于为什么放弃推荐? -& ...

  3. 大数据之路week01--自学之集合_2(List)

    在学习过了Collection之后,接下来我们将去学习List, 先看API文档: List集合的特有功能:(没有列出Collection也有的功能) A:添加功能  add(int index, E ...

  4. Go 基础学习笔记(3)| 第一个程序 “helloworld”

       //第一个程序总要说的清楚才行.   //建议先运行起第一个程序实践后,再看后面的具体解答 一.helloworld 编写运行 1.编写源程序,在 ~ /hello/src  编写hello.g ...

  5. access,trunk,hybrid端口分析

    1.access 接收:当数据没有tag时打上pvidtag进入,若有则看是否与pvid相等,相等则接收,不想等则丢弃. 转发:看tag是否等于pvid,若等则去tag发送,否则不处理. 2.trun ...

  6. Java基础语法03-数组

    四数组 数组概念: 数组就是用于存储数据的长度固定的容器,多个数据的数据类型要一致. 百科:数组(array),就是相同数据类型的元素按一定顺序排列的集合,就是把有限个类型相同的变量用一个名字命名,以 ...

  7. cnblogs侧边栏访客统计 小插件

    之前博客的侧边栏一直用的是flagcounter,直观简洁又好看,近期恍然发现被博客园禁了.禁用原因据说是由于flagcounter将香港(HongKong).台湾(TaiWan)和澳门(Macau) ...

  8. docker搭建本地registry

    第一步:拉取registry镜像 [root@localhost iso]# docker image pull registry Using default tag: latest latest: ...

  9. 小白历险记:spingboot之helloworld

    还记得入职第一天的时候,先安装了相关的软件,配置了环境.boss叫我写的第一个程序:搭建一个springboot工程,输出helloworld. 哈哈话不多说,回忆一下. 1.打开IDEA,点击Cre ...

  10. Linux下编写-makefile-详细教程(跟我一起写-Makefile-Markdown整理版)

    目录 概述 关于程序的编译和链接 Makefile 介绍 Makefile的规则 一个演示例子 make是怎样工作的 makefile中使用变量 让make自己主动推导 另类风格的makefile 清 ...