万法同源

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

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

![avatar]\(......)

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

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

2、base64字符串转化为图片

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

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

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

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

Flask展示图片例子

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

HTML代码:

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
</head>
<body>
<img src="data:;base64,{{ img }}">
</body>
</html>

Flask后台代码:

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

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

完善车标测试app

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

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

后台Flask代码:

# -*- coding: utf-8 -*-
# @Author : 王翔
# @JianShu : 清风Python
# @Date : 2019/7/25 1:37
# @Software : PyCharm
# @version :Python 3.7.3
# @File : app.py from flask import Flask, render_template, g
import sqlite3
import random
import base64 app = Flask(__name__)
DATABASE = 'static/db/car.db'
app.secret_key = 'Breeze Python' def connect_db():
return sqlite3.connect(DATABASE) @app.before_request
def before_request():
g.db = connect_db() @app.teardown_request
def teardown_request(exception):
if hasattr(g, 'db'):
g.db.close() def query_db(query, args=()):
cur = g.db.execute(query, args)
rv = [dict((cur.description[idx][0], value)
for idx, value in enumerate(row)) for row in cur.fetchall()]
if not query.startswith('select'):
g.db.commit()
return rv[0] if rv else None @app.route('/car')
@app.route('/')
def index():
id = random.randint(1, 141)
car_info = query_db('select name,image,founded,models,website from car_logo where id={}'.format(id))
car_info['image'] = base64.b64encode(car_info['image']).decode('ascii')
print(car_info)
return render_template('index.html', car=car_info) if __name__ == '__main__':
app.run(host='0.0.0.0', port=7000)

前台HTML代码:

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1 ,user-scalable=no">
<title>清风python</title>
<link rel="icon" href="{{ url_for('static',filename='favicon.ico') }}">
<link rel="stylesheet" href="{{ url_for('static',filename='css/bootstrap.min.css') }}">
<link rel="stylesheet" href="{{ url_for('static',filename='css/main.css') }}">
<script src="{{ url_for('static',filename='js/jquery.min.js') }}"></script>
</head>
<body> <div class="container container-small">
<div class="content">
<div class="header">
车标学习
</div>
<div class="block-info">
<div class="form-group" align="center">
<p><img class="img-rounded" src="data:;base64,{{ car.image }}"></p>
</div>
<div class="form-group car-info">
<table class="table table-hover table-bordered table_show table-condensed">
<tbody>
<tr>
<th>品牌</th>
<td id="idiom_name"> {{ car.Name }}</td>
</tr>
<tr>
<th>始于</th>
<td id="idiom_meaning">{{ car.founded }}</td>
</tr>
<tr>
<th>车型</th>
<td id="idiom_example"> {{ car.models }}</td>
</tr>
<tr>
<th>官网</th>
<td id="idiom_example"> {{ car.website }}</td>
</tr>
</tbody>
</table>
</div> <div class="form-group ">
<a class="form-control btn-primary" href="{{ url_for('index') }}">换一个</a>
</div> </div>
</div>
<div class="footer">
©2019-欢迎关注我的公众号:<a href="https://www.jianshu.com/u/d23fd5012bed">清风Python</a>
</div>
</div> </body>
</html>

The End

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

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

最新文章

  1. nginx源码分析之模块初始化
  2. response 下载文件
  3. 九步轻松实现SVN创建管理项目
  4. 快速分析apk工具aapt的使用
  5. 使用VisualVM监控远程服务器JVM
  6. Maven学习总结(二)——Maven项目构建过程练习_转载
  7. ZOJ-3929 Deque and Balls (DP+找规律)
  8. poj 1386 Play on Words 有向欧拉回路
  9. (转)C++笔记:面向对象编程基础
  10. SVN记录使用过程中出现的错误(一)
  11. 响应的系统设置的事件——Configuration类简介
  12. zookeeper分布式搭建
  13. 16. 使用Exhibitor管理ZooKeeper
  14. Python——模块——时间模块
  15. scrapy 部署
  16. UML 类图几种关系的总结(图文并茂、案例详解)
  17. 学习下新塘M0芯片的下载方法
  18. linux 挂载硬盘 + 对硬盘 分区
  19. Drupal的$messages是怎么显示的?
  20. 将ORACLE数据库更改为归档模式;写出步骤

热门文章

  1. NOIP模拟26
  2. 使用requests实现人人网登录,并做cookie维持
  3. html5自动弹出软键盘的方法
  4. Java把一个文件,输出成多个文件
  5. 创建基于OData的Web API - Knowledge Builder API, Part IV: Write Controller
  6. omcat配置多域名站点启动时项目重复加载多次
  7. 基于Windows下永久破解jetbrains公司的系列产品(Idea, pycharm,clion,phpstorm)
  8. codeblocks在Ubuntu 18 下的安装
  9. pat 1041 Be Unique(20 分)
  10. Freemarker + xml 实现Java导出word