Python matplotlib模块,是扩展的MATLAB的一个绘图工具库,它可以绘制各种图形

建议安装 Anaconda后使用 ,集成了很多第三库,基本满足大家的需求,下载地址,对应选择python 2.7 或是 3.5 的就可以了:
https://www.continuum.io/downloads#windows

脚本默认执行方式:
             1.获取当前文件夹下的1.log文件
             2.将数据格式化为矩阵
             3.以矩阵的列索引为x坐标,行索引为y坐标,值为z坐标
             4.绘制曲面图
测试数据
测试所用数据:
 
r_gain=
79.000000f,  89.000000f, 104.000000f, 120.000000f, 135.000000f,
149.000000f, 160.000000f, 172.000000f, 176.000000f, 172.000000f,
164.000000f, 159.000000f, 143.000000f, 128.000000f, 113.000000f, 
97.000000f,  81.000000f,
r_gain=
84.000000f, 100.000000f, 120.000000f, 136.000000f, 156.000000f,
176.000000f, 192.000000f, 204.000000f, 208.000000f, 204.000000f,
196.000000f, 180.000000f, 164.000000f, 144.000000f, 124.000000f,
108.000000f,  92.000000f,
r_gain=
91.000000f, 112.000000f, 132.000000f, 156.000000f, 176.000000f,
200.000000f, 224.000000f, 240.000000f, 248.000000f, 244.000000f,
228.000000f, 208.000000f, 188.000000f, 164.000000f, 140.000000f,
120.000000f,  99.000000f,
r_gain=
99.000000f, 120.000000f, 144.000000f, 172.000000f, 200.000000f,
228.000000f, 256.000000f, 276.000000f, 284.000000f, 280.000000f,
264.000000f, 240.000000f, 208.000000f, 180.000000f, 156.000000f,
132.000000f, 105.000000f,
r_gain=107.000000f,
128.000000f, 156.000000f, 184.000000f, 216.000000f, 256.000000f,
288.000000f, 308.000000f, 320.000000f, 316.000000f, 296.000000f,
264.000000f, 228.000000f, 196.000000f, 164.000000f, 140.000000f,
113.000000f,
r_gain=111.000000f,
132.000000f, 160.000000f, 192.000000f, 232.000000f, 272.000000f,
304.000000f, 332.000000f, 340.000000f, 336.000000f, 316.000000f,
284.000000f, 244.000000f, 204.000000f, 172.000000f, 144.000000f,
117.000000f,
r_gain=109.000000f,
136.000000f, 164.000000f, 196.000000f, 232.000000f, 276.000000f,
312.000000f, 336.000000f, 348.000000f, 344.000000f, 320.000000f,
288.000000f, 248.000000f, 208.000000f, 172.000000f, 144.000000f,
117.000000f,
r_gain=111.000000f,
132.000000f, 160.000000f, 192.000000f, 228.000000f, 268.000000f,
304.000000f, 328.000000f, 340.000000f, 332.000000f, 312.000000f,
280.000000f, 240.000000f, 200.000000f, 168.000000f, 140.000000f,
119.000000f,
r_gain=101.000000f,
128.000000f, 152.000000f, 180.000000f, 212.000000f, 248.000000f,
280.000000f, 304.000000f, 312.000000f, 308.000000f, 288.000000f,
260.000000f, 224.000000f, 192.000000f, 160.000000f, 136.000000f,
109.000000f,
r_gain=
95.000000f, 116.000000f, 140.000000f, 164.000000f, 192.000000f,
224.000000f, 248.000000f, 272.000000f, 280.000000f, 272.000000f,
256.000000f, 232.000000f, 200.000000f, 176.000000f, 152.000000f,
128.000000f, 101.000000f,
r_gain=
87.000000f, 108.000000f, 128.000000f, 148.000000f, 172.000000f,
192.000000f, 216.000000f, 232.000000f, 236.000000f, 232.000000f,
220.000000f, 200.000000f, 180.000000f, 156.000000f, 136.000000f,
116.000000f,  95.000000f,
r_gain=
80.000000f,  96.000000f, 112.000000f, 132.000000f, 148.000000f,
168.000000f, 180.000000f, 192.000000f, 196.000000f, 196.000000f,
184.000000f, 172.000000f, 156.000000f, 136.000000f, 120.000000f,
104.000000f,  88.000000f,
r_gain=
69.000000f,  85.000000f,  96.000000f, 111.000000f, 127.000000f,
141.000000f, 153.000000f, 160.000000f, 164.000000f, 159.000000f,
157.000000f, 145.000000f, 135.000000f, 120.000000f, 104.000000f, 
88.000000f,  77.000000f,

曲面图脚本
# -*- coding: utf-8 -*-
 
from matplotlib import pyplot as plt
from mpl_toolkits.mplot3d import Axes3D
from pandas import DataFrame
 
 
def draw(x, y, z):
    '''
    采用matplolib绘制曲面图
    :param x: x轴坐标数组
    :param y: y轴坐标数组
    :param z: z轴坐标数组
    :return:
    '''
    X = x
    Y = y
    Z = z
 
    fig = plt.figure()
    ax = fig.add_subplot(111, projection='3d')
    ax.plot_trisurf(X, Y, Z)
    plt.show()
 
if __name__ == '__main__':
    '''
       默认执行方式:
             1.获取当前文件夹下的1.log文件
             2.将数据格式化为矩阵
             3.以矩阵的列索引为x坐标,行索引为y坐标,值为z坐标
             4.绘制曲面图
    '''
    data = {}
    index_origin = 0
    f = open("1.log")
    line = f.readline()
    while line:
        data[index_origin] = line.split('=')[-1].replace(' ', '').split('f,')[0:-1]
        index_origin = index_origin + 1
        line = f.readline()
    f.close()
    df = DataFrame(data)
    df = df.T
 
    x = []
    for i in range(len(df.index)):
        x = x + list(df.columns)
    print(x)
 
    y = []
    for i in range(len(df.index)):
        for m in range(17):
            y.append(i)
    print(y)
 
    z = []
    for i in range(len(df.index)):
        z = z + df[i:i + 1].values.tolist()[0]
    z = map(float, z)
    print (z)
    draw(x, y, z)

【python】pandas & matplotlib 数据处理 绘制曲面图的更多相关文章

  1. python中matplotlib所绘制的图包含了很多的对象

    上图中的top=‘off’意思是说顶部的grid lines 看不见. 去除frame,意思就是将这个矩形给去除掉,spine意思是脊柱 bars = plt.bar(pos, popularity, ...

  2. Python使用matplotlib模块绘制多条折线图、散点图

    用matplotlib模块 #!usr/bin/env python #encoding:utf-8 ''' __Author__:沂水寒城 功能:折线图.散点图测试 ''' import rando ...

  3. python 运用numpy库与matplotlib库绘制数据图

    代码一 import numpy as np import matplotlib.pyplot as plt x=np.linspace(0,6,100) y=np.cos(2*np.pi*x)*np ...

  4. Python数据分析-Matplotlib图标绘制

    Matplotlib介绍 Matplotlib是一个强大的Python绘图和数据可视化的工具包. Matplotlib的主要功能 Matplotlib是python中的一个包,主要用于绘制2D图形(当 ...

  5. python使用matplotlib:subplot绘制多个子图

    1 问题描述 matploglib 能够绘制出精美的图表, 有些时候, 我们希望把一组图放在一起进行比较, 有没有什么好的方法呢? matplotlib 中提供的 subplot 可以很好的解决这个问 ...

  6. Python Pandas 时间序列双轴折线图

    时间序列pv-gmv双轴折线图 import numpy as np import pandas as pd import matplotlib.pyplot as plt n = 12 date_s ...

  7. 使用matplotlib库绘制函数图

    函数如下: z = x^2 * y / (x^4 +y^2) 代码如下: import numpy as np import matplotlib.pyplot as plt import mpl_t ...

  8. Python——Pandas 时间序列数据处理

    介绍 Pandas 是非常著名的开源数据处理库,我们可以通过它完成对数据集进行快速读取.转换.过滤.分析等一系列操作.同样,Pandas 已经被证明为是非常强大的用于处理时间序列数据的工具.本节将介绍 ...

  9. python使用matplotlib:subplot绘制多个子图 不规则画图

    https://www.cnblogs.com/xiaoboge/p/9683056.html

随机推荐

  1. MySql联接算法

    联接算法是MySql数据库用于处理联接的物理策略.在MySql 5.5版本仅支持Nested-Loops Join算法,如果联接表上有索引时,Nested-Loops Join是非常高效的算法.如果有 ...

  2. RedHat6.2搭建FTP服务器

    我的环境: A:Red Hat Enterprise 6.2 IP:192.168.16.12 此机作测试端 B:Red Hat Enterprise 6.2 IP:192.168.16.13 此机做 ...

  3. LoadRunner编程之跳出迭代【exit(-1)和return 0】

    只运行了一次迭代,就结束了. LR脚本实践:关于lr中exit(-1)和return 0的区别 exit(-1):从当前action里面exit(-1)所在行,当前迭代里面直接退出来,终止运行:   ...

  4. TFS任务更新

    由于不熟悉TFS任务更新的操作,花了四五个小时一个个的新建任务.下图是部分更新的任务截图: 每个任务的估计时间为3~5小时,每位成员的任务总时长均为19~20小时. 项目完成需要的总时间为135小时.

  5. lucene prefixQuery

    prefixQuery是lucene的一个前缀匹配的搜索功能,但是它的前缀匹配不是完全的前缀匹配,的query生成是:易* 但是能把所有带有易字的都搜到... 下面是实验:出现了交易...

  6. ***Jquery下Ajax与PHP数据交换

    一.前台传递字符串变量,后台返回字符串变量(非json格式) Javascript代码: 这里,为了解决Ajax数据传递出现的汉字乱码,在字符串传递之前,使用javascript函数escape()对 ...

  7. Org-mode 任务添加提醒

    org-mode中的约会日程有提醒功能,这样设置就行: ;; ;;; 提醒 ;; (require 'appt) ;; (appt-activate t);启用约会提醒 ;; (setq appt-d ...

  8. zabbix中文配置指南(转)-服务器监控

    一.Zabbix简介 1.1 Zabbix简介 Zabbix是一个企业级的开源分布式监控解决方案,由一个国外的团队持续维护更新,软件可以自由下载使用,运作团队靠提供收费的技术支持赢利.官方网站:htt ...

  9. 01-学前入门VS各个组成部分

    1)快捷打开运行窗口(Windows+R) 里面输入devenv命令快捷打开VS 2)解决方案,项目及类之间的关系(解决方案包含项目-项目包含-类) 例如可以这样比喻: 解决方案:相当于公司 项目:相 ...

  10. javascript和python取dict字典对象的不同

    dict1={"a":1,"b":2,"22a":44} JS: dict1.a 和 dict1["a"]都可以 pyt ...