1.库的引用
import warnings
warnings.filterwarnings("ignore")
import pandas as pd
import numpy as np
import os
os.chdir(r"E:\BaiduNetdiskDownload\数据") #指定工作路径
2.定义计算权重函数
#计算权重,并将标准化后数据保存下来
def get_entropy_weight(data):
"""
:param data: 评价指标数据框
:return: 各指标权重列表
"""
# 数据标准化
data = (data - data.min())/(data.max() - data.min())
# 保存标准化后的数据
data.to_excel("标准化后数据.xlsx", sheet_name="sheet1", index= False,encoding="utf-8")
print(data) #直接在运行时打印出标准化后的数据
#计算k
m,n=data.shape #m是行,n是列
#将dataframe格式转化为matrix格式
data=data.as_matrix(columns=None)
k=1/np.log(m)
yij=data.sum(axis=0)
#计算pij
pij=data/yij
test=pij*np.log(pij)
test=np.nan_to_num(test)
#计算每种指标的信息熵
ej=-k*(test.sum(axis=0))