2013-08-09 19:04 27805人阅读 评论(1) 收藏 举报
 分类:
Python(71)  matplotlib(11)  Numpy_Scipy(14) 

版权声明:本文为博主原创文章,未经博主允许不得转载。

使用matplotlib的示例:调整字体-设置刻度、坐标、colormap和colorbar等

  1. # -*- coding: utf-8 -*-
  2. #**********************************************************
  3. import os
  4. import numpy as np
  5. import wlab #pip install wlab
  6. import matplotlib
  7. import matplotlib.cm as cm
  8. import matplotlib.pyplot as plt
  9. from matplotlib.ticker import MultipleLocator
  10. from scipy.interpolate import griddata
  11. matplotlib.rcParams['xtick.direction'] = 'out'
  12. matplotlib.rcParams['ytick.direction'] = 'out'
  13. #**********************************************************
  14. FreqPLUS=['F06925','F10650','F23800','F18700','F36500','F89000']
  15. #
  16. FindPath='/d3/MWRT/R20130805/'
  17. #**********************************************************
  18. fig = plt.figure(figsize=(8,6), dpi=72, facecolor="white")
  19. axes = plt.subplot(111)
  20. axes.cla()#清空坐标轴内的所有内容
  21. #指定图形的字体
  22. font = {'family' : 'serif',
  23. 'color'  : 'darkred',
  24. 'weight' : 'normal',
  25. 'size'   : 16,
  26. }
  27. #**********************************************************
  28. # 查找目录总文件名中保护F06925,EMS和txt字符的文件
  29. for fp in FreqPLUS:
  30. FlagStr=[fp,'EMS','txt']
  31. FileList=wlab.GetFileList(FindPath,FlagStr)
  32. #
  33. LST=[]#地表温度
  34. EMS=[]#地表发射率
  35. TBH=[]#水平极化亮温
  36. TBV=[]#垂直极化亮温
  37. #
  38. findex=0
  39. for fn in FileList:
  40. findex=findex+1
  41. if (os.path.isfile(fn)):
  42. print(str(findex)+'-->'+fn)
  43. #fn='/d3/MWRT/R20130805/F06925_EMS60.txt'
  44. data=wlab.dlmread(fn)
  45. EMS=EMS+list(data[:,1])#地表发射率
  46. LST=LST+list(data[:,2])#温度
  47. TBH=TBH+list(data[:,8])#水平亮温
  48. TBV=TBV+list(data[:,9])#垂直亮温
  49. #-----------------------------------------------------------
  50. #生成格点数据,利用griddata插值
  51. grid_x, grid_y = np.mgrid[275:315:1, 0.60:0.95:0.01]
  52. grid_z = griddata((LST,EMS), TBH, (grid_x, grid_y), method='cubic')
  53. #将横纵坐标都映射到(0,1)的范围内
  54. extent=(0,1,0,1)
  55. #指定colormap
  56. cmap = matplotlib.cm.jet
  57. #设定每个图的colormap和colorbar所表示范围是一样的,即归一化
  58. norm = matplotlib.colors.Normalize(vmin=160, vmax=300)
  59. #显示图形,此处没有使用contourf #>>>ctf=plt.contourf(grid_x,grid_y,grid_z)
  60. gci=plt.imshow(grid_z.T, extent=extent, origin='lower',cmap=cmap, norm=norm)
  61. #配置一下坐标刻度等
  62. ax=plt.gca()
  63. ax.set_xticks(np.linspace(0,1,9))
  64. ax.set_xticklabels( ('275', '280', '285', '290', '295',  '300',  '305',  '310', '315'))
  65. ax.set_yticks(np.linspace(0,1,8))
  66. ax.set_yticklabels( ('0.60', '0.65', '0.70', '0.75', '0.80','0.85','0.90','0.95'))
  67. #显示colorbar
  68. cbar = plt.colorbar(gci)
  69. cbar.set_label('$T_B(K)$',fontdict=font)
  70. cbar.set_ticks(np.linspace(160,300,8))
  71. cbar.set_ticklabels( ('160', '180', '200', '220', '240',  '260',  '280',  '300'))
  72. #设置label
  73. ax.set_ylabel('Land Surface Emissivity',fontdict=font)
  74. ax.set_xlabel('Land Surface Temperature(K)',fontdict=font) #陆地地表温度LST
  75. #设置title
  76. titleStr='$T_B$ for Freq = '+str(float(fp[1:-1])*0.01)+'GHz'
  77. plt.title(titleStr)
  78. figname=fp+'.png'
  79. plt.savefig(figname)
  80. plt.clf()#清除图形
  81. #plt.show()
  82. print('ALL -> Finished OK')

上面的例子中,每个保存的图,都是用同样的colormap,并且每个图的颜色映射值都是一样的,也就是说第一个图中如果200表示蓝色,那么其他图中的200也表示蓝色。

示例的图形如下:

 
2
2

使用matplotlib的示例:调整字体-设置刻度、坐标、colormap和colorbar等的更多相关文章

  1. 使用matplotlib的示例:调整字体-设置colormap和colorbar

    使用matplotlib的示例:调整字体-设置colormap和colorbar # -*- coding: utf-8 -*- #********************************** ...

  2. 05. Matplotlib 1 |图表基本元素| 样式参数| 刻度 注释| 子图

    1.Matplotlib简介及图表窗口 Matplotlib → 一个python版的matlab绘图接口,以2D为主,支持python.numpy.pandas基本数据结构,运营高效且有较丰富的图表 ...

  3. Matplotlib 图表的基本参数设置

    1.图名,图例,轴标签,轴边界,轴刻度,轴刻度标签 # 图名,图例,轴标签,轴边界,轴刻度,轴刻度标签等 df = pd.DataFrame(np.random.rand(10,2),columns= ...

  4. (数据科学学习手札100)搞定matplotlib中的字体设置

    本文示例文件已上传至我的Github仓库https://github.com/CNFeffery/DataScienceStudyNotes 1 简介 matplotlib作为数据可视化的利器,被广泛 ...

  5. IDEA或Webstorm设置Ctrl+滚轮调整字体大小

    按Ctrl+Shift+A,出现搜索框 输入mouse: 点击打开这个设置:勾选 点击ok,之后就可以通过Ctrl+滚轮 调整字体大小了.

  6. 用matplotlib绘制带误差的条形图及中英文字体设置

    #!/usr/bin/env python3 ## 以下是一个带误差条的条形图的例子,演示了误差条形图的绘制及中英文字体设置 import numpy as np import matplotlib ...

  7. IDEA设置Ctrl+滚轮调整字体大小

    IDEA设置Ctrl+滚轮调整字体大小(转载)   按Ctrl+Shift+A,出现搜索框 输入mouse: 点击打开这个设置:勾选 点击ok,之后就可以通过Ctrl+滚轮 调整字体大小了.

  8. IDEA设置Ctrl+滚轮调整字体大小(转载)

    按Ctrl+Shift+A,出现搜索框 输入mouse: 点击打开这个设置:勾选 点击ok,之后就可以通过Ctrl+滚轮 调整字体大小了. 转载自:http://www.cnblogs.com/LUA ...

  9. Css调整字体间距

    在span div 某些元素中有时候会用到调整字体的间距,设置方法: letter-spacing:15px;  

随机推荐

  1. centos7安装MPlyaer

    最近更换了centos7系统,对新系统的操作不是太熟悉.大神轻喷.昨晚突然想要下个电影看看,结果发现系统自带的播放器支持的视频格式有限,google查了一下,他们推荐使用MPlayer.于是经过一通g ...

  2. Linux 解压压缩命令

    一.概述: 1.压缩命令: 命令格式:tar  -zcvf   压缩文件名.tar.gz   被压缩文件名 可先切换到当前目录下.压缩文件名和被压缩文件名都可加入路径. 2.解压缩命令: 命令格式:t ...

  3. 2017-03-05 CentOS中结合Nginx部署dotnet core Web应用程序

    Visual Studio Live 倒计时2天,当然这是美国倒计时两天,中国应该是在3月8日的凌晨,正值"3.8妇女节".提前祝广大的女性同志节日快乐,当然还有奋斗在一线的程序媛 ...

  4. jsp用tags传递参数

    <computer:trangleTag sideA="12" sideB="12" sideC="12"/>表示以字符串传递s ...

  5. 分布式_理论_08_Consistent Hash(一致性哈希算法)

    一.前言 五.参考资料 1.分布式理论(八)—— Consistent Hash(一致性哈希算法)

  6. LeetCode OJ:Delete Node in a Linked List(链表节点删除)

    Write a function to delete a node (except the tail) in a singly linked list, given only access to th ...

  7. Nhibernate系列学习之(三) Criteria查询表达式增删改查

    Criteria查询表达式: 正如我们所见,Expression对查询语句的表达式进行了封装和限制,下表列出了Expression所有的方法,以及每个方法所对应的查询表达式及其限制. Restrict ...

  8. java 网页 保存上传文件

    网页请求提交到另外一个jsp 进行处理 index.jsp <%@ page language="java" import="java.util.*" p ...

  9. 浅谈FFT(快速傅里叶变换)

    本文主要简单写写自己在算法竞赛中学习FFT的经历以及一些自己的理解和想法. FFT的介绍以及入门就不赘述了,网上有许多相关的资料,入门的话推荐这篇博客:FFT(最详细最通俗的入门手册),里面介绍得很详 ...

  10. c# Http请求之HttpClient

    利用HttpClient进行Http请求,基于此,简单地封装了下: using System; using System.Collections.Generic; using System.Colle ...