python熵权法求权重

1.库的引用import warningswarnings.filterwarnings("ignore")import pandas as pdimport numpy as npimport osos.chdir(r"E:\BaiduNetdiskDownload\数据") #指定工作路径2.定义计算权重函数#计算权重,并将标准化后数据保存下来def get_entro...
摘要由CSDN通过智能技术生成

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))
  • 1
    点赞
  • 26
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值