Python实用记录(九):将不同的图绘制在一起、将不同txt文档中的数据绘制多条折线图

简介: 这篇文章介绍了如何使用Python的OpenCV库将多张图片合并为一张图片显示,以及如何使用matplotlib库从不同txt文档中读取数据并绘制多条折线图。

1.将不同的图绘制在一起

import cv2
import numpy as np

def mul_pics(img1,img2,img3,img4,img5,img6,img7,img8):
    """为了结合多张图绘制成一张图 利用 np.hstack、np.vstack实现一幅图像中显示多幅图片"""
    results = (img1,img2,img3,img4)
    results1 = (img5,img6,img7,img8)
    # np.hstack()将两个数组按列放到一起
    line1 = np.hstack(results[:2])
    line2 = np.hstack(results[2:4])
    line3 = np.hstack(results1[:2])
    line4 = np.hstack(results1[2:4])
    combined = np.vstack([line1, line2])  # 将多个数组按行放到一起
    combined1 = np.vstack([line3, line4])  # 将多个数组按行放到一起
    cv2.namedWindow('Result', cv2.WINDOW_NORMAL)
    cv2.namedWindow('Result1', cv2.WINDOW_NORMAL)
    cv2.imshow('Result', combined)
    cv2.imshow('Result1', combined1)
    cv2.imwrite('F:\epycharm\HSB_match\pic\Result_a1_a4.jpg',combined)
    cv2.imwrite('F:\epycharm\HSB_match\pic\Result_a4_a8.jpg',combined1)
    cv2.waitKey(0)

# img1 = cv2.imread('F:\epycharm\HSB_match\pic\A1.png',cv2.IMREAD_COLOR)
# img2 = cv2.imread('F:\epycharm\HSB_match\pic\A2.png',cv2.IMREAD_COLOR)
# img3 = cv2.imread('F:\epycharm\HSB_match\pic\A3.png',cv2.IMREAD_COLOR)
# img4 = cv2.imread('F:\epycharm\HSB_match\pic\A4.png',cv2.IMREAD_COLOR)
# img5 = cv2.imread('F:\epycharm\HSB_match\pic\A5.png',cv2.IMREAD_COLOR)
# img6 = cv2.imread('F:\epycharm\HSB_match\pic\A6.png',cv2.IMREAD_COLOR)
# img7 = cv2.imread('F:\epycharm\HSB_match\pic\A7.png',cv2.IMREAD_COLOR)
# img8 = cv2.imread('F:\epycharm\HSB_match\pic\A8.png',cv2.IMREAD_COLOR)
# mul_pics(img1,img2,img3,img4,img5,img6,img7,img8)

2.将不同txt文档中的数据绘制多条折线图

在这里插入图片描述

import matplotlib.pyplot as plt

file = open('F:\epycharm\HSB_match\excel_file\决策树.txt')  #决策
file1 = open('F:\epycharm\HSB_match\excel_file\随机森林20.txt')  #随机-20
file2 = open('F:\epycharm\HSB_match\excel_file\随机森林25.txt')  #随机-25
file3 = open('F:\epycharm\HSB_match\excel_file\随机森林30.txt')  #随机-30

data = file.readlines() #读取文档数据
data1 = file1.readlines() #读取文档数据
data2 = file2.readlines() #读取文档数据
data3 = file3.readlines() #读取文档数据

para_1 = []  #新建列表,决策
para_2 = []  #新建列表,随机-25
para_3 = []  #新建列表,随机-20
para_4 = []  #新建列表,随机-30
for num in data:
    # split用于将每一行数据用逗号分割成多个对象
    #取分割后的第0列,转换成float格式后添加到para_1列表中
    para_1.append(float(num.split(',')[0]))
for num in data1:
    # split用于将每一行数据用逗号分割成多个对象
    # 取分割后的第0列,转换成float格式后添加到para_1列表中
    para_2.append(float(num.split(',')[0]))
for num in data2:
    # split用于将每一行数据用逗号分割成多个对象
    #取分割后的第0列,转换成float格式后添加到para_1列表中
    para_3.append(float(num.split(',')[0]))
for num in data3:
    # split用于将每一行数据用逗号分割成多个对象
    #取分割后的第0列,转换成float格式后添加到para_1列表中
    para_4.append(float(num.split(',')[0]))

plt.rcParams['font.sans-serif'] = ['SimHei']
plt.rcParams['axes.unicode_minus'] = False
para_1.sort()
# for i in range(len(para_1)):
#     f = open('F:\epycharm\HSB_match\excel_file\data2.txt', 'a')
#     f.write(str(i))
#     f.write('\n')
#
para_2.sort()
para_3.sort()
print(min(para_1))
print(max(para_1))
print('............')
print(min(para_2))
print(max(para_2))
print('............')
print(min(para_3))
print(max(para_3))
print('............')
para_4.sort()

# for i in range(len(para_2)):
#     f = open('F:\epycharm\HSB_match\excel_file\data3.txt', 'a')
#     f.write(str(i))
#     f.write('\n')
plt.figure()
plt.xlabel('steps', fontsize=10)  # x轴表示
plt.ylabel('R2_score', fontsize=10)  # y轴表示
plt.title('决策树R2分数对比图')
plt.plot(para_1,markerfacecolor='r',label='决策树')
plt.plot(para_2,markerfacecolor='b',label='随机森林-20')
plt.plot(para_3,markerfacecolor='b',label='随机森林-25')
# plt.plot(para_4,markerfacecolor='b',label='随机森林-30')
plt.legend()
plt.show()

如果对于一行有两个数据

def loadData0(flieName1, flieName2):
    inFile1 = open(flieName1, 'r')  # 以只读方式打开某fileName文件
    inFile2 = open(flieName2, 'r')
    # 定义两个空list,用来存放文件中的数据
    x = []
    y = []

    for index, line in enumerate(inFile1):
        x.append(float(line))
    for index, line in enumerate(inFile2):
        y.append(float(line))

    return x, y  # 注意,若返回的为元组(x, y),则画图的时候python不能区分大小
目录
相关文章
|
5月前
|
XML 数据格式 Python
从手动编辑到代码生成:Python 助你高效创建 Word 文档
本文介绍如何用Python实现Word文档自动化生成,结合python-docx、openpyxl和matplotlib库,高效完成报告撰写、数据插入与图表生成,大幅提升办公效率,降低格式错误,实现数据驱动的文档管理。
843 2
|
5月前
|
数据采集 Web App开发 数据可视化
Python零基础爬取东方财富网股票行情数据指南
东方财富网数据稳定、反爬宽松,适合爬虫入门。本文详解使用Python抓取股票行情数据,涵盖请求发送、HTML解析、动态加载处理、代理IP切换及数据可视化,助你快速掌握金融数据爬取技能。
3325 1
|
5月前
|
Java 数据挖掘 数据处理
(Pandas)Python做数据处理必选框架之一!(一):介绍Pandas中的两个数据结构;刨析Series:如何访问数据;数据去重、取众数、总和、标准差、方差、平均值等;判断缺失值、获取索引...
Pandas 是一个开源的数据分析和数据处理库,它是基于 Python 编程语言的。 Pandas 提供了易于使用的数据结构和数据分析工具,特别适用于处理结构化数据,如表格型数据(类似于Excel表格)。 Pandas 是数据科学和分析领域中常用的工具之一,它使得用户能够轻松地从各种数据源中导入数据,并对数据进行高效的操作和分析。 Pandas 主要引入了两种新的数据结构:Series 和 DataFrame。
616 0
|
5月前
|
JSON 算法 API
Python采集淘宝商品评论API接口及JSON数据返回全程指南
Python采集淘宝商品评论API接口及JSON数据返回全程指南
|
5月前
|
JSON API 数据安全/隐私保护
Python采集淘宝拍立淘按图搜索API接口及JSON数据返回全流程指南
通过以上流程,可实现淘宝拍立淘按图搜索的完整调用链路,并获取结构化的JSON商品数据,支撑电商比价、智能推荐等业务场景。
|
6月前
|
数据采集 关系型数据库 MySQL
python爬取数据存入数据库
Python爬虫结合Scrapy与SQLAlchemy,实现高效数据采集并存入MySQL/PostgreSQL/SQLite。通过ORM映射、连接池优化与批量提交,支持百万级数据高速写入,具备良好的可扩展性与稳定性。
|
IDE API 开发工具
|
IDE 开发工具 开发者
Python函数说明文档:编写清晰易懂的文档字符串
Python函数说明文档:编写清晰易懂的文档字符串
418 1
|
Python
Python 的编码规范和最佳实践: 解释 Python 的文档字符串(docstring)是什么?如何编写好的文档字符串?
【4月更文挑战第16天】Python docstrings是注释,用于说明代码功能。放置于对象定义前,用三引号包围。遵循PEP 257,使用reStructuredText格式,确保简洁、完整、准确。例如: ```markdown ```python def add(a, b): """ 计算两数之和。 参数: a -- 第一加数 b -- 第二加数 返回: 和 """ return a + b ``` ```
608 0
|
IDE 程序员 开发工具
Python 进阶指南(编程轻松进阶):十一、注释、文档字符串和类型提示
Python 进阶指南(编程轻松进阶):十一、注释、文档字符串和类型提示
647 0

推荐镜像

更多