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

作者:未来战士biubiu 时间:2023-02-02 09:41:40 

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()

来源:https://blog.csdn.net/u010105243/article/details/76856071

标签:Python,matplotlib,colormap
0
投稿

猜你喜欢

  • Python之文字转图片方法

    2022-02-12 07:11:10
  • Pivot,信息组织的梦想之窗

    2009-12-25 14:32:00
  • javascript合并表格单元格实例代码

    2023-07-02 05:30:39
  • python脚本调用iftop 统计业务应用流量的思路详解

    2022-02-07 02:37:12
  • 使用 XML 模板 (MSSQL手册)

    2008-09-04 14:25:00
  • Django REST framework 限流功能的使用

    2023-11-11 07:09:35
  • BeautifulSoup中find和find_all的使用详解

    2023-11-08 21:00:22
  • 一步步教你利用webpack如何搭一个vue脚手架(超详细讲解和注释)

    2023-07-02 17:00:47
  • 做新产品?悠着点

    2009-03-01 13:10:00
  • 推荐给大家看的设计书

    2009-02-23 12:17:00
  • MySQL之select、distinct、limit的使用

    2024-01-22 04:41:20
  • SQL Server中应当怎样得到自动编号字段

    2009-01-15 12:48:00
  • sqlserver存储过程中SELECT 与 SET 对变量赋值的区别

    2024-01-14 09:50:26
  • Yii框架实现乐观锁与悲观锁流程详解

    2023-11-16 13:38:38
  • 详解python使用Nginx和uWSGI来运行Python应用

    2023-07-25 20:40:55
  • Pandas处理时间序列数据操作详解

    2021-06-19 07:21:45
  • Python如何优雅删除字符列表空字符及None元素

    2023-10-26 19:17:00
  • python闭包和装饰器你了解吗

    2022-01-11 00:46:02
  • 浅谈pycharm使用及设置方法

    2023-12-18 21:17:47
  • select @@identity的应用(得到刚插入数据的ID)

    2009-09-10 11:24:00
  • asp之家 网络编程 m.aspxhome.com