psogos 2022-05-02 19:58 采纳率: 83.7%
浏览 21
已结题

运行如下python代码,画图窗口未呈现就重新不见,请问是怎么回事


import pandas as pd
from sklearn.cluster import KMeans
import matplotlib.pyplot as plt
inputfile = 'consumption_data.xls'
outputfile = 'data_type.xlsx'
k = 3
iteration = 500
data = pd.read_excel(inputfile, index_col = 'Id')
data_zs = 1.0*(data-data.mean())/data.std() # 数据标准化
model = KMeans(n_clusters = k, n_jobs = 4, max_iter = iteration,random_state=1234)
model.fit(data_zs)
r1 = pd.Series(model.labels_).value_counts()
r2 = pd.DataFrame(model.cluster_centers_)
r = pd.concat([r2, r1], axis = 1)
r.columns = list(data.columns) + ['number']
print(r)
r = pd.concat([data, pd.Series(model.labels_, index = data.index)], axis = 1)
r.columns = list(data.columns) + ['sorts']
r.to_excel(outputfile)
def density_plot(data):

   # plt.rcParams['font.sans-serif'] = ['DejaVuSans.ttc'] # 用来正常显示中文标签
    plt.rcParams['axes.unicode_minus'] = False  # plt.rcParams['axes.unicode_minus'] = False # 用来正常显示负号用来正常显示负号
    p = data.plot(kind='kde', linewidth=2, subplots=True, sharex=False)
    p = data.plot(kind='kde', linewidth=2, subplots=True, sharex=False)
    [p[i].set_ylabel(u'density')for i in range(k)]
    plt.legend()
    return plt
pic_output = 'pd'
for i in range(k):
    density_plot(data[r[u'sorts']==i]).savefig(u'%s%s.png'%(pic_output,i))
    
  • 写回答

2条回答 默认 最新

  • bj_0163_bj 2022-05-02 20:16
    关注

    你没有plt.show()

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

问题事件

  • 已结题 (查看结题原因) 5月5日
  • 已采纳回答 5月2日
  • 创建了问题 5月2日

悬赏问题

  • ¥15 C#调用python代码(python带有库)
  • ¥15 矩阵加法的规则是两个矩阵中对应位置的数的绝对值进行加和
  • ¥15 活动选择题。最多可以参加几个项目?
  • ¥15 飞机曲面部件如机翼,壁板等具体的孔位模型
  • ¥15 vs2019中数据导出问题
  • ¥20 云服务Linux系统TCP-MSS值修改?
  • ¥20 关于#单片机#的问题:项目:使用模拟iic与ov2640通讯环境:F407问题:读取的ID号总是0xff,自己调了调发现在读从机数据时,SDA线上并未有信号变化(语言-c语言)
  • ¥20 怎么在stm32门禁成品上增加查询记录功能
  • ¥15 Source insight编写代码后使用CCS5.2版本import之后,代码跳到注释行里面
  • ¥50 NT4.0系统 STOP:0X0000007B