import pandas as pd
import numpy as np
# 读取你的CSV数据(假设数据已经加载到 DataFrame df 中)
# df = pd.read_csv('your_data.csv')
# 确保保存时间是datetime类型
df['保存时间'] = pd.to_datetime(df['保存时间'])
# 假设喂料电机实时转速的列名为 '喂料电机实时转速'
# 设置一个阈值来识别上升沿(从低值变为高值)
threshold = 10 # 根据你的数据调整该阈值
# 识别上升沿(从较低值上升到高于阈值的点)
df['shifted'] = df['喂料电机实时转速'].shift(1) # 前一行的值
df['上升沿'] = (df['喂料电机实时转速'] > threshold) & (df['shifted'] <= threshold)
# 提取上升沿的时间戳
rising_edges = df[df['上升沿'] == True]['保存时间']
# 计算连续上升沿之间的时间差
rising_intervals = rising_edges.diff().dropna()
# 打印每个周期的时间长度
print("周期时长:")
print(rising_intervals)
# 如果你想要平均周期时间
mean_cycle_time = rising_intervals.mean()
print(f"\n平均周期时间: {mean_cycle_time}")