Python matplotlib的使用并自定义colormap的方法


Posted in Python onDecember 13, 2018

0.前言

添加colormap的对象是灰度图,可以变成热量图,从而更加明显的发现一些规律,适用于一些雷达图像等

from PIL import Image
# 将彩色图片转换成黑白图片
im=Image.open("./pic.jpg").convert('L')
# 保存图片
im.save("image.jpg")

1.从灰色图片中读取数据,转换成colormap图

import matplotlib.pyplot as plt
import matplotlib.image as mpimg
import matplotlib as mpl
from PIL import Image
import numpy as np

# 自定义colormap
def colormap():
  return mpl.colors.LinearSegmentedColormap.from_list('cmap', ['#FFFFFF', '#98F5FF', '#00FF00', '#FFFF00','#FF0000', '#8B0000'], 256)

# 读取灰度图
data=mpimg.imread('./gray.jpg')
# 如果需要固定colorbar的范围,可以设置参数vmin,vmax,具体参考
                 #http://matplotlib.org/api/image_api.html

# 设定每个图的colormap和colorbar所表示范围是一样的,即归一化 
plt.imsave('colormap.jpg',data, cmap=colormap())

这里没有显示出来colorbar的数值分布,得到的图像是等大的

2.从txt文本中读取二维数据,转换成自定义colormap图

#python 3
import numpy as np
import matplotlib.pyplot as plt
import matplotlib as mpl
import matplotlib.colors as colors


# load data
def loaddata(i): # 文件编号
  path = './input/data/trainPingliu/trainPingliu%d.txt' % i
  data = np.loadtxt(path)
  return data


# 生成图片格式自定义
def colormap():
  # 白青绿黄红
  cdict = ['#FFFFFF', '#9ff113', '#5fbb44', '#f5f329', '#e50b32']
  # 按照上面定义的colordict,将数据分成对应的部分,indexed:代表顺序
  return colors.ListedColormap(cdict, 'indexed')


# for i in range(1, 10000):
# 加载数据
data = loaddata(1)
fig = plt.figure()
# 加载图片设置
my_cmap = colormap()

# 第一个子图,按照默认配置
ax = fig.add_subplot(221)
ax.imshow(data)

# 第二个子图,使用api自带的colormap
ax = fig.add_subplot(222)
cmap = mpl.cm.bwr # 蓝,白,红
ax.imshow(data, cmap=cmap)

# 第三个子图增加一个colorbar
ax = fig.add_subplot(223)
cmap = mpl.cm.winter # 冬季风格
im = ax.imshow(data, cmap=my_cmap)
plt.colorbar(im) # 增加colorbar

# 第四个子图可以调整colorbar
ax = fig.add_subplot(224)
cmap = mpl.cm.rainbow
# 这里设置colormap的固定值
norm = mpl.colors.Normalize(vmin=-1, vmax=1)
im=ax.imshow(data,cmap=cmap)
plt.colorbar(im,cmap=cmap, norm=norm,ticks=[-1,0,1])


# 显示
plt.show()

以上这篇Python matplotlib的使用并自定义colormap的方法就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Python 相关文章推荐
windows下安装python paramiko模块的代码
Feb 10 Python
Python中dictionary items()系列函数的用法实例
Aug 21 Python
Python while、for、生成器、列表推导等语句的执行效率测试
Jun 03 Python
利用python实现命令行有道词典的方法示例
Jan 31 Python
python实现音乐下载器
Apr 15 Python
Django中使用MySQL5.5的教程
Dec 18 Python
Tensorflow矩阵运算实例(矩阵相乘,点乘,行/列累加)
Feb 05 Python
Python 剪绳子的多种思路实现(动态规划和贪心)
Feb 24 Python
Python实现对adb命令封装
Mar 06 Python
Python多个装饰器的调用顺序实例解析
May 22 Python
python字符串的index和find的区别详解
Jun 20 Python
在Mac中配置Python虚拟环境过程解析
Jun 22 Python
python实现给scatter设置颜色渐变条colorbar的方法
Dec 13 #Python
matplotlib实现热成像图colorbar和极坐标图的方法
Dec 13 #Python
对matplotlib改变colorbar位置和方向的方法详解
Dec 13 #Python
python用plt画图时,cmp设置方法
Dec 13 #Python
python reverse反转部分数组的实例
Dec 13 #Python
对Python的zip函数妙用,旋转矩阵详解
Dec 13 #Python
python将list转为matrix的方法
Dec 12 #Python
You might like
c#中的实现php中的preg_replace
2009/12/21 PHP
php中PDO方式实现数据库的增删改查
2015/05/17 PHP
微信开发之php表单微信中自动提交两次问题解决办法
2017/01/08 PHP
PHP+redis实现的购物车单例类示例
2019/02/02 PHP
Avengerls vs Newbee BO3 第一场2.18
2021/03/10 DOTA
JavaScript中获取未知对象属性的代码
2011/04/27 Javascript
JS中setInterval、setTimeout不能传递带参数的函数的解决方案
2013/04/28 Javascript
js 自定义个性下拉选择框示例
2013/08/20 Javascript
jQuery is()函数用法3例
2014/05/06 Javascript
详解Matlab中 sort 函数用法
2016/03/20 Javascript
基于javascript实现文字无缝滚动效果
2016/03/22 Javascript
如何高效率去掉js数组中的重复项
2016/04/12 Javascript
深入浅析JavaScript中数据共享和数据传递
2016/04/25 Javascript
jQuery验证插件validate使用详解
2016/05/11 Javascript
Bootstrap Table使用方法解析
2016/10/19 Javascript
详解JavaScript中的属性和特性
2016/12/08 Javascript
jQuery插件HighCharts实现的2D对数饼图效果示例【附demo源码下载】
2017/03/09 Javascript
JavaScript实现的可变动态数字键盘控件方式实例代码
2017/07/15 Javascript
解决Vue不能检测数组或对象变动的问题
2018/02/24 Javascript
js如何找出字符串中的最长回文串
2018/06/04 Javascript
element-ui使用导航栏跳转路由的用法详解
2018/08/22 Javascript
vue从后台渲染文章列表以及根据id跳转文章详情详解
2020/12/14 Vue.js
[37:35]DOTA2上海特级锦标赛A组资格赛#1 Secret VS MVP.Phx第二局
2016/02/25 DOTA
Python中int()函数的用法浅析
2017/10/17 Python
Python迭代器与生成器用法实例分析
2018/07/09 Python
Python中查看变量的类型内存地址所占字节的大小
2019/06/26 Python
python中sympy库求常微分方程的用法
2020/04/28 Python
Python简单实现词云图代码及步骤解析
2020/06/04 Python
python中round函数如何使用
2020/06/19 Python
给儿子的表扬信
2014/01/15 职场文书
会计电算化专业求职信
2014/06/10 职场文书
优秀员工自荐书
2015/03/06 职场文书
英文自荐信范文
2015/03/25 职场文书
祝寿主持词
2015/07/02 职场文书
Python下opencv使用hough变换检测直线与圆
2021/06/18 Python
使用CSS自定义属性实现骨架屏效果
2022/06/21 HTML / CSS