RError.com

RError.com Logo RError.com Logo

RError.com Navigation

  • 主页

Mobile menu

Close
  • 主页
  • 系统&网络
    • 热门问题
    • 最新问题
    • 标签
  • Ubuntu
    • 热门问题
    • 最新问题
    • 标签
  • 帮助
主页 / 问题 / 1414623
Accepted
Konstantin
Konstantin
Asked:2022-07-28 22:19:12 +0000 UTC2022-07-28 22:19:12 +0000 UTC 2022-07-28 22:19:12 +0000 UTC

设置 pcolormesh matplotlib

  • 772

excel(data25.xls)中有数据,我正在尝试基于它们构建图表。事实证明不是很好......即。由于最大值是2969,而且下降的很快,所以整个颜色网格都在最大值附近(saved_figure.png),基本上整个图都是蓝色的,不好...

我这样构建图表:

import xlwings as xw
import matplotlib.pyplot as plt
 
def get_row_col_index(sheet):
    'Индексы для диапазона что бы забрать данные'
    row = 0
    col = 0
    # find col
    for i in range(1, 5000):
        val = sheet.range((1, i)).value
        if val == None:
            col = (1, i - 1)
            break
    # find row
    for i in range(1, 5000):
        val = sheet.range((i, 1)).value
        if val == None:
            row = (i - 1, 1)
            break
 
    return row, col
 
def get_data_in_excel(row: tuple, col: tuple) -> list:
    val = sheet.range((2, 2), (row[0], col[1])).options(
        ndim=2).value  # с 2 - т.к. нужно ислючить размерность длины по X, Y
    return val
 
wb = xw.Book(f'data25.xls')
sheet = wb.sheets['Лист1']
 
row, col = get_row_col_index(sheet)
val = get_data_in_excel(row, col)
 
plt.imshow(val, cmap='jet', interpolation = 'bicubic', vmax=0.5)
plt.show()
# plt.savefig('saved_figure.png')

我得到: 资源

我想得到这样的东西: 想要的

数据:excel链接

PS。所需的图表是从基于相同 excel 数据的另一个程序中获得的。

python python-3.x
  • 1 1 个回答
  • 59 Views

1 个回答

  • Voted
  1. Best Answer
    CrazyElf
    2022-08-01T16:50:25Z2022-08-01T16:50:25Z

    您的数据准备代码可以减少到几行。但是,对于图片本身,它暂时不能很好地发挥作用,你想要什么。我会多想的。

    import numpy as np
    import pandas as pd
    import matplotlib.pyplot as plt
    import matplotlib
    
    df = pd.read_excel('data25.xls')
    val = df.values[:,1:].T
    val[val < 1e-3] = 0.04
    plt.figure(figsize=(10,10))
    plt.imshow(val, cmap='jet', interpolation = 'bicubic', vmax=0.1)
    plt.show()
    # plt.savefig('saved_figure.png')
    

    在此处输入图像描述

    您的数据并不像看起来那样。例如,它们也可以使用对数表示如下:

    df = pd.read_excel('data25.xls')
    val = df.values[:,1:].T
    shift = val[val>0].min()
    val = np.log(val + shift)
    plt.figure(figsize=(10,10))
    plt.imshow(val, cmap='magma', interpolation = 'bicubic', vmax=0.5)
    plt.show()
    

    在此处输入图像描述

    用轮廓更新变体:

    plt.figure(figsize=(10,10))
    plt.imshow(val, cmap='jet', interpolation = 'bicubic', vmax=0.1)
    X, Y = np.meshgrid(range(df.shape[1]), range(df.shape[0]-1))
    Z = val
    plt.contour(X, Y, Z, sorted([2**(-n) for n in range(10)]));
    plt.show()
    

    在此处输入图像描述

    • 1

相关问题

Sidebar

Stats

  • 问题 10021
  • Answers 30001
  • 最佳答案 8000
  • 用户 6900
  • 常问
  • 回答
  • Marko Smith

    我看不懂措辞

    • 1 个回答
  • Marko Smith

    请求的模块“del”不提供名为“default”的导出

    • 3 个回答
  • Marko Smith

    "!+tab" 在 HTML 的 vs 代码中不起作用

    • 5 个回答
  • Marko Smith

    我正在尝试解决“猜词”的问题。Python

    • 2 个回答
  • Marko Smith

    可以使用哪些命令将当前指针移动到指定的提交而不更改工作目录中的文件?

    • 1 个回答
  • Marko Smith

    Python解析野莓

    • 1 个回答
  • Marko Smith

    问题:“警告:检查最新版本的 pip 时出错。”

    • 2 个回答
  • Marko Smith

    帮助编写一个用值填充变量的循环。解决这个问题

    • 2 个回答
  • Marko Smith

    尽管依赖数组为空,但在渲染上调用了 2 次 useEffect

    • 2 个回答
  • Marko Smith

    数据不通过 Telegram.WebApp.sendData 发送

    • 1 个回答
  • Martin Hope
    Alexandr_TT 2020年新年大赛! 2020-12-20 18:20:21 +0000 UTC
  • Martin Hope
    Alexandr_TT 圣诞树动画 2020-12-23 00:38:08 +0000 UTC
  • Martin Hope
    Air 究竟是什么标识了网站访问者? 2020-11-03 15:49:20 +0000 UTC
  • Martin Hope
    Qwertiy 号码显示 9223372036854775807 2020-07-11 18:16:49 +0000 UTC
  • Martin Hope
    user216109 如何为黑客设下陷阱,或充分击退攻击? 2020-05-10 02:22:52 +0000 UTC
  • Martin Hope
    Qwertiy 并变成3个无穷大 2020-11-06 07:15:57 +0000 UTC
  • Martin Hope
    koks_rs 什么是样板代码? 2020-10-27 15:43:19 +0000 UTC
  • Martin Hope
    Sirop4ik 向 git 提交发布的正确方法是什么? 2020-10-05 00:02:00 +0000 UTC
  • Martin Hope
    faoxis 为什么在这么多示例中函数都称为 foo? 2020-08-15 04:42:49 +0000 UTC
  • Martin Hope
    Pavel Mayorov 如何从事件或回调函数中返回值?或者至少等他们完成。 2020-08-11 16:49:28 +0000 UTC

热门标签

javascript python java php c# c++ html android jquery mysql

Explore

  • 主页
  • 问题
    • 热门问题
    • 最新问题
  • 标签
  • 帮助

Footer

RError.com

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

帮助

© 2023 RError.com All Rights Reserve   沪ICP备12040472号-5