通过python读取txt文件和绘制柱形图的实现代码
作者:Amigo瓜波 发布时间:2023-11-23 11:24:43
标签:python,柱形图,txt文件
目的
临床数据的记录时间和对应标签(逗号后面的数字)记录在txt文件里,要把标签转换为3类标签,并且计算出每个标签的分别持续时间,然后绘制成柱形图方便查阅。
小难点分析:
(1)txt的切割读取对应内容
(2)时间差计算
txt文件如图:
使用效果
首先将原始txt转换为 左列新标签 右列持续时间
绘制为柱形图
为了直观,每次只最多显示 2个小时,同时横坐标还是按照临床的记录时间顺序。
代码实现
# -*- coding: utf-8 -*-
from datetime import datetime
import matplotlib.pyplot as plt
from matplotlib.font_manager import FontProperties
font_set = FontProperties(fname=r"c:\windows\fonts\simsun.ttc", size=12)
address = "D:/XXXXXX/"
patient = "XXXXX"
year = '2020' # or 2020
txt_address = address + patient + "/timetable.txt"
filename = address + patient + "/newTimeTable.txt" # 保存的txt地址
# 读取txt的相应内容
def showLabel():
content = []
label = []
rawtime = []
with open(txt_address, 'r', encoding="utf-8") as f:
lines = f.readlines() # 返回的是列表
print("文件的行数:%d" % len(lines))
for line in lines:
content_value = line.split(sep=',') # 分为[0]和[1]
time_value = content_value[0].split(sep=year)
content_value = content_value[1].split(sep='\n')
temp_time = year + time_value[-1]
rawtime.append(temp_time)
content.append(content_value[0])
# 去掉第一行的line和转换label
for i in range(1, len(lines)): # range是左闭右开
number = int(content[i])
if number == 4:
label_value = 1 # label 1 表示癫痫发作
elif number == 1:
label_value = 0 # label 0 表示数据缺失
else:
label_value = -1 # label -1 表示非癫痫发作
label.append(label_value)
del rawtime[0] # 去掉第一行的line
length = len(lines)
return label, rawtime, length
# 计算时间差
def getTimeSpan(new_label,time,length):
time_span = []
time_label = []
temp = datetime.strptime(time[0], "%Y-%m-%d %H:%M:%S")
for i in range(0, length - 2):
if new_label[i] != new_label[i + 1]:
end_time = datetime.strptime(time[i + 1], "%Y-%m-%d %H:%M:%S")
diff = end_time - temp
temp = end_time
# time_span.append(diff) 标准化时间
time_span.append(round(diff.total_seconds() / 60, 2)) # 保留两位小数
time_label.append(new_label[i])
return time_span, time_label
# 画图,按照标签内容给图上色
def showTimeandLabel(time_span,time_label):
Yanse = []
for i in time_label:
if i == 0:
yanse = 'blue'
elif i == -1:
yanse = 'gray'
else:
yanse = 'red'
Yanse.append(yanse)
plt.bar(range(len(time_span)), time_span, width=0.8, tick_label=time_label, color=Yanse)
plt.xlabel('标签', fontproperties=font_set)
plt.ylabel("持续时间(分钟)", fontproperties=font_set)
plt.title("patient: " + patient, size=20)
plt.ylim(0, 120)
plt.show()
# 保存到txt
def txtSave(time_span, time_label):
# w:向文件中写入内容时,会先清空原文件中的内容,
with open(filename, 'w', encoding="utf-8") as f:
line_number = len(time_label)
for i in range(line_number):
f.write(str(time_label[i])+" "+str(time_span[i]))
f.write("\n")
def main():
new_label, time, length = showLabel()
time_span, time_label = getTimeSpan(new_label, time, length)
txtSave(time_span, time_label)
showTimeandLabel(time_span, time_label)
if __name__ == '__main__':
main()
来源:https://blog.csdn.net/Amigo_1997/article/details/114766182


猜你喜欢
- 如下所示:BaseException +-- SystemExit +-- KeyboardInterrupt +-- GeneratorE
- 本文实例分析了GO语言文件的创建与打开用法。分享给大家供大家参考。具体分析如下:文件操作是个很重要的话题,使用也非常频繁,熟悉如何操作文件是
- ARP欺骗又称ARP毒化或ARP攻击,是针对以太网地址解析协议ARP的一种攻击技术,通过欺骗局域网内访问者PC的网关MAC地址,使访问者PC
- 前言这部分已经折腾我两天了,还是没有头绪,可能还会折腾更久,最后在第三天上午解决问题,在一个不起眼的地方被坑了,jQuery加载的问题。会者
- 列表渲染 key 的原理和作用key就是为该节点做身份标识,如果对key绑定index的值,那么很容易出现问题:1.若对数据进行:逆序添加、
- 需求背景智慧农业里有一个很重要的功能是控制温室生长环境,让农作物生长的更好。于是,我们需要在曲线上根据不同农作物设置不同的环境数据。为了方便
- MySQL 5.0.16的乱码问题可以用下面的方法解决:1.设置phpMyAdminLanguage:Chinese simplified
- 前言最近在学习vue框架的基本原理,看了一些技术博客以及一些对vue源码的简单实现,对数据代理、数据劫持、模板解析、变异数组方法、双向绑定有
- 一、概念二维列表的元素还是列表(列表的嵌套),称之为二维列表。需要通过行标和列标来访问二维列表的元素二、创建二维列表1、追加一维列标来生成二
- 功能:获取android设备中某一个app的cpu和内存环境:python和adb使用方法:使用adb连接android设备,打开将要测试的
- 写在前面和小伙伴们分享一些Python 网络编程的一些笔记,博文为《Python Cookbook》读书后笔记整理博文涉及内容包括:TCP/
- Python传入参数的方法有:位置参数、默认参数、可变参数、关键字参数、和命名关键字参数、以及各种参数调用的组合写在前面Python唯一支持
- 固定路由的面包屑导航我们在配置router的时候,可以将面包屑数据配置在meta中,例如路由配置:{ path: '/p
- 本文实例讲述了Python基于回溯法子集树模板实现图的遍历功能。分享给大家供大家参考,具体如下:问题一个图:A --> BA --&g
- 目录1.简介2.如何解决3.虚线框类代码4.测试UI界面如下图所示5.拖动时的效果图如下所示1.简介看到很多才学QT的人都会问为啥无边框拖动
- mysql连接超时和mysql连接错误在生产环境中,偶尔且不规律的出现mysql连接超时和创建连接出错的问题:15-09-2020 13:2
- for循环语句的对象是可迭代对象,可迭代对象需要实现__iter__或iter方法,并返回一个迭代器,什么是迭代器呢?迭代器只需要实现 __
- 1.delete不能使自动编号返回为起始值。但是truncate能使自动增长的列的值返回为默认的种子 2.truncate只能一次清空,不能
- @num=1; 把num类型转成nvarchar类型 cast(@num as nvarchar(10)) @str='123
- 机器视觉从Google的无人驾驶汽车到可以识别假钞的自动售卖机,机器视觉一直都是一个应用广泛且具有深远的影响和雄伟的愿景的领域。这里我们将重