当前位置: 首页 > article >正文

别再手动算排名了!用Python+TOPSIS法5分钟搞定多指标评价(附完整代码)

用PythonTOPSIS法5分钟搞定多指标评价排名当你面对一堆供应商评估表格、学生综合评分数据或者项目优先级排序表时是否还在用Excel手动计算加权分数每次调整权重都要重新算一遍不仅效率低下还容易出错。今天我要分享的TOPSIS法配合Python的Pandas和Numpy库能让你在5分钟内搞定这些繁琐的计算而且结果比手动计算更客观科学。TOPSISTechnique for Order Preference by Similarity to Ideal Solution即优劣解距离法它的核心思想很直观找出每个方案距离理想解最近同时距离负理想解最远的那个方案作为最优解。这种方法特别适合处理多指标决策问题比如供应商评估价格、交货期、质量等多维度打分员工绩效考核KPI多项指标综合投资项目选择收益率、风险、周期等权衡学术评价论文、专利、项目等多指标排名1. 环境准备与数据加载首先确保你已安装Python和Jupyter Notebook推荐Anaconda发行版。我们需要用到以下几个核心库import pandas as pd import numpy as np from sklearn.preprocessing import MinMaxScaler假设我们有一份供应商评估的Excel数据包含以下指标供应商价格(万元)交货周期(天)质量合格率(%)售后服务评分A12015984.2B15010954.5C10020993.8用Pandas加载数据非常简单df pd.read_excel(supplier_evaluation.xlsx, index_col供应商) print(df.head())注意数据中的指标类型不同价格和交货周期是越小越好成本型而质量合格率和售后服务评分是越大越好效益型。这是TOPSIS处理前的关键认知。2. 数据预处理指标正向化TOPSIS要求所有指标同向化都转为越大越好。我们需要区分指标类型效益型指标越大越好如质量合格率成本型指标越小越好如价格区间型指标落在某个区间最好如温度中间型指标越接近某个值越好如pH值对于我们的示例数据只需处理成本型指标。常用正向化方法有倒数法1/x差值法max(x) - x标准化法(max(x) - x)/(max(x) - min(x))这里使用差值法实现# 成本型指标列名 cost_columns [价格(万元), 交货周期(天)] # 正向化处理 for col in cost_columns: df[col] df[col].max() - df[col] print(正向化后的数据) print(df)处理后的数据中所有指标都变为效益型——数值越大代表表现越好。3. 数据标准化与权重分配不同指标的量纲和数量级不同需要标准化处理。常用方法有向量归一化x_ij / sqrt(sum(x_ij^2))Min-Max标准化(x - min)/(max - min)Z-score标准化(x - mean)/stdTOPSIS通常采用向量归一化# 向量归一化 normalized_df df / np.sqrt((df**2).sum()) print(归一化矩阵) print(normalized_df)权重分配有三种常见方法等权重法所有指标权重相同主观赋权法如AHP层次分析法客观赋权法如熵权法这里演示等权重和熵权法两种实现# 方法1等权重 equal_weights np.ones(df.shape[1]) / df.shape[1] # 方法2熵权法 def entropy_weight(X): # 避免log(0) X X 1e-10 # 计算比重 P X / X.sum(axis0) # 计算熵值 E np.sum(-P * np.log(P), axis0) / np.log(len(X)) # 计算差异系数 D 1 - E # 计算权重 W D / D.sum() return W entropy_weights entropy_weight(df.values) print(熵权法计算的权重, entropy_weights)4. TOPSIS核心计算步骤有了标准化矩阵和权重后就可以计算正负理想解和相对接近度了。def topsis(data, weights): # 加权标准化矩阵 weighted_matrix data * weights # 确定正负理想解 ideal_best weighted_matrix.max() ideal_worst weighted_matrix.min() # 计算距离 dist_best np.sqrt(((weighted_matrix - ideal_best)**2).sum(axis1)) dist_worst np.sqrt(((weighted_matrix - ideal_worst)**2).sum(axis1)) # 计算相对接近度 score dist_worst / (dist_best dist_worst) return score # 使用熵权法权重计算 df[TOPSIS评分] topsis(normalized_df, entropy_weights) df[排名] df[TOPSIS评分].rank(ascendingFalse) print(最终结果) print(df.sort_values(排名))5. 完整代码封装与使用建议将上述步骤封装成一个函数方便重复使用def topsis_evaluation(input_file, cost_columns, output_fileNone): TOPSIS多指标评价完整流程 参数 input_file: 输入Excel文件路径 cost_columns: 成本型指标列名列表 output_file: 结果输出路径(可选) 返回 带评分和排名的DataFrame # 1. 数据加载 df pd.read_excel(input_file, index_col0) # 2. 正向化处理 for col in cost_columns: df[col] df[col].max() - df[col] # 3. 数据标准化 normalized_df df / np.sqrt((df**2).sum()) # 4. 计算权重(熵权法) weights entropy_weight(df.values) # 5. TOPSIS计算 df[TOPSIS评分] topsis(normalized_df, weights) df[排名] df[TOPSIS评分].rank(ascendingFalse) # 6. 结果输出 if output_file: df.to_excel(output_file) return df.sort_values(排名) # 使用示例 result topsis_evaluation( input_filesupplier_evaluation.xlsx, cost_columns[价格(万元), 交货周期(天)], output_filesupplier_ranking_result.xlsx )实际使用时你只需要准备Excel数据第一列为评价对象名称确定哪些列是成本型指标越小越好调用这个函数指定输入输出路径提示对于区间型或中间型指标可以在正向化步骤添加相应处理逻辑。完整代码可在GitHub仓库获取。我在多个供应商评估项目中使用这个方法后发现它有三大优势客观性避免了人为赋权的主观性灵活性权重方法可自由选择熵权法、AHP等可视化结果可以方便地用Python做进一步分析展示一个常见的问题是当某个指标值出现极端异常时怎么办我的经验是预处理阶段使用Winsorize方法处理极端值或者考虑用标准化方法代替原始数据对于明显错误的数据应该人工检查修正

相关文章:

别再手动算排名了!用Python+TOPSIS法5分钟搞定多指标评价(附完整代码)

用PythonTOPSIS法5分钟搞定多指标评价排名 当你面对一堆供应商评估表格、学生综合评分数据或者项目优先级排序表时,是否还在用Excel手动计算加权分数?每次调整权重都要重新算一遍,不仅效率低下,还容易出错。今天我要分享的TOPSIS…...

告别密码!用WindTerm的SSH密钥登录Linux服务器,保姆级图文教程(含权限设置避坑)

告别密码时代:用WindTerm实现SSH密钥安全登录的终极指南 每次输入冗长复杂的服务器密码时,那种烦躁感是否让您想砸键盘?密码泄露导致的安全事件频发,传统密码验证方式早已不是最优解。作为现代开发者,是时候拥抱更安全…...

ARM CP15 c1控制寄存器功能详解与配置指南

1. ARM CP15控制寄存器深度解析在ARM架构的嵌入式系统开发中,系统控制协处理器CP15扮演着核心角色。作为处理器与开发者之间的关键接口,CP15通过一组精心设计的控制寄存器,为系统提供了精细化的控制能力。其中,c1控制寄存器尤为重…...

多模态RAG技术:跨模态信息检索与生成的实践指南

1. 多模态RAG技术解析:从理论到实践的革命性跨越在信息爆炸的时代,我们每天面对的海量文档中,有超过60%的内容以PDF等富文本格式存在,其中包含大量图表、公式和复杂排版。传统基于OCR的文本提取方法在处理这类文档时,平…...

别再手动建模了!Unity Terrain地形工具保姆级教程:从草地、树木到风系统,5分钟打造你的第一个游戏场景

别再手动建模了!Unity Terrain地形工具保姆级教程:从草地、树木到风系统,5分钟打造你的第一个游戏场景 刚接触Unity的开发者常常会陷入一个误区:认为高质量的地形必须通过复杂的建模软件才能实现。实际上,Unity内置的…...

STM32+LVGL实战避坑:从显示错位到触摸不灵,我的嵌入式GUI移植调试记录

STM32LVGL实战避坑:从显示错位到触摸不灵,我的嵌入式GUI移植调试记录 当我在STM32F407上第一次看到那个歪斜的按钮时,内心是崩溃的。作为一个嵌入式开发者,我本以为LVGL的移植会像官方文档描述的那样顺利,但现实却给了…...

用C语言手搓一个2048游戏核心逻辑(附XTU-OJ 1239题解)

从零实现2048游戏核心逻辑:C语言算法精解与XTU-OJ 1239实战 在算法学习的道路上,将抽象规则转化为具体代码的能力至关重要。2048这款经典数字合并游戏,恰好提供了绝佳的算法训练场景。本文将带你从零开始,用C语言构建完整的游戏核…...

Screenpipe:本地AI记忆体,事件驱动与隐私优先的屏幕活动自动化

1. 项目概述:为你的屏幕装上AI记忆如果你和我一样,每天在电脑前处理海量信息,从代码、文档到会议、网页,那么“我上周三下午在哪个网页上看到过那个API文档?”或者“昨天开会时客户提到的那个具体需求是什么&#xff1…...

Equalizer APO终极教程:免费打造Windows专业级音频均衡器

Equalizer APO终极教程:免费打造Windows专业级音频均衡器 【免费下载链接】equalizerapo Equalizer APO mirror 项目地址: https://gitcode.com/gh_mirrors/eq/equalizerapo 想要彻底提升Windows电脑的音频体验吗?Equalizer APO作为一款免费开源的…...

如何在PotPlayer中免费实现字幕实时翻译?百度翻译插件完整指南

如何在PotPlayer中免费实现字幕实时翻译?百度翻译插件完整指南 【免费下载链接】PotPlayer_Subtitle_Translate_Baidu PotPlayer 字幕在线翻译插件 - 百度平台 项目地址: https://gitcode.com/gh_mirrors/po/PotPlayer_Subtitle_Translate_Baidu 你是否在观看…...

如何用ContextMenuManager彻底掌控Windows右键菜单

如何用ContextMenuManager彻底掌控Windows右键菜单 【免费下载链接】ContextMenuManager 🖱️ 纯粹的Windows右键菜单管理程序 项目地址: https://gitcode.com/gh_mirrors/co/ContextMenuManager 在日常的Windows使用中,右键菜单是我们最频繁接触…...

孤舟笔记 并发篇十八 为什么启动线程不能直接调用run()方法?调用两次start()又会怎样?这个设计藏着大智慧

文章目录 一、先说结论:run() 和 start() 的核心区别二、直接调用 run():根本没有新线程start() 源码做了什么? 三、调两次 start():直接报错四、正确姿势:需要新线程就创建新对象五、Thread 的状态机:为什…...

别再只看ROC了!用‘价格斜率’构建ETF轮动策略,实测改善回撤(附Python代码)

价格斜率:重构ETF动量轮动的量化新视角 当大多数量化交易者还在用传统的收益率指标(ROC)衡量ETF动量时,市场已经悄悄奖励那些发现价格斜率价值的先行者。去年一位私募基金经理在内部测试中发现,将沪深300ETF的20日价格…...

保姆级教程:手把手教你修改PX4机型文件,让自定义无人机在QGC上完美显示

深度解析PX4机型文件定制:从脚本修改到QGC无缝集成实战指南 当你完成了一架自定义无人机的PX4固件开发,满心欢喜地打开QGroundControl(QGC)准备调试时,却发现机型列表中根本找不到自己的作品——这种挫败感我太熟悉了…...

TVA与CNN的历史性对决(3)

重磅预告:本专栏将独家连载新书《AI视觉技术:从入门到进阶》精华内容。本书是《AI视觉技术:从进阶到专家》的权威前导篇,特邀美国 TypeOne 公司首席科学家、斯坦福大学博士 Bohan 担任技术顾问。Bohan师从美国三院院士、“AI教母”…...

RH850 RS-CANFD中断配置保姆级教程:从Channel 2实战到寄存器位操作详解

RH850 RS-CANFD中断配置实战指南:从寄存器解析到Channel 2完整实现 当你在RH850评估板上第一次尝试配置RS-CANFD中断时,是否曾被那些神秘的寄存器位和中断向量表搞得晕头转向?作为从STM32转战瑞萨平台的工程师,我完全理解这种困惑…...

CNN与TVA的历史性对决(2)

重磅预告:本专栏将独家连载新书《AI视觉技术:从入门到进阶》精华内容。本书是《AI视觉技术:从进阶到专家》的权威前导篇,特邀美国 TypeOne 公司首席科学家、斯坦福大学博士 Bohan 担任技术顾问。Bohan师从美国三院院士、“AI教母”…...

Discord集成Ollama:本地大模型AI助手部署与实战指南

1. 项目概述与核心价值 最近在折腾AI应用集成,发现一个挺有意思的项目叫 kevinthedang/discord-ollama 。简单来说,它就是一个让你能在Discord聊天服务器里,直接调用本地部署的Ollama大语言模型的机器人。想象一下,你和朋友在Di…...

【Docker 27量子计算环境适配白皮书】:20年CNCF+量子实验室联合验证的7大不可绕过兼容陷阱

更多请点击: https://intelliparadigm.com 第一章:Docker 27量子计算环境适配的演进逻辑与战略定位 随着量子计算软件栈从原型验证迈向工程化部署,容器化运行时对量子模拟器、QPU驱动接口及混合量子-经典工作流的支持能力成为关键瓶颈。Dock…...

AI辅助全栈开发实战:基于Cursor构建MERN待办事项应用

1. 项目概述:一个由AI驱动的全栈待办事项应用最近在GitHub上看到一个挺有意思的项目,叫santosflores/todo_list_cursor。光看名字,你可能会觉得这又是一个平平无奇的待办事项列表应用,市面上类似的工具没有一千也有八百。但如果你…...

3步掌握NHSE:动物森友会存档编辑器的深度应用指南

3步掌握NHSE:动物森友会存档编辑器的深度应用指南 【免费下载链接】NHSE Animal Crossing: New Horizons save editor 项目地址: https://gitcode.com/gh_mirrors/nh/NHSE NHSE(New Horizons Save Editor)是一款专为《集合啦&#xff…...

DeepSeek LeetCode 2040.两个有序数组的第 K 小乘积 Python3实现

python from typing import List import bisectclass Solution:def kthSmallestProduct(self, nums1: List[int], nums2: List[int], k: int) -> int:# 统计乘积 < mid 的个数def count(mid: int) -> int:cnt 0for a in nums1:if a > 0:# a * b < mid > b…...

Substrate跨链桥实战:从架构设计到安全部署

1. 项目概述与核心价值最近在折腾一个跨链数据聚合的项目&#xff0c;中间件选型时&#xff0c;一个叫buremba/sub-bridge的开源项目进入了我的视野。这名字乍一看&#xff0c;sub很容易让人联想到 Substrate 区块链框架&#xff0c;而bridge则直指“桥”这个核心功能。没错&am…...

Ubuntu 20.04下搞定gici-open编译:从glog报错到ceres版本冲突的保姆级排坑指南

Ubuntu 20.04下gici-open编译全攻略&#xff1a;从依赖管理到实战调试 在GNSS/INS/Camera多传感器融合领域&#xff0c;gici-open作为上海交通大学最新开源的高精度定位框架&#xff0c;凭借其整合RTKLIB、OKVIS等知名算法的优势&#xff0c;正成为研究者和工程师关注的焦点。…...

如何用XXMI启动器轻松管理游戏模组:完整指南

如何用XXMI启动器轻松管理游戏模组&#xff1a;完整指南 【免费下载链接】XXMI-Launcher Modding platform for GI, HSR, WW and ZZZ 项目地址: https://gitcode.com/gh_mirrors/xx/XXMI-Launcher XXMI-Launcher是一款开源的游戏模组管理平台&#xff0c;专门为《原神》…...

SketchUp STL插件:5分钟实现3D设计到打印的无缝转换

SketchUp STL插件&#xff1a;5分钟实现3D设计到打印的无缝转换 【免费下载链接】sketchup-stl A SketchUp Ruby Extension that adds STL (STereoLithography) file format import and export. 项目地址: https://gitcode.com/gh_mirrors/sk/sketchup-stl 你是否在Sket…...

ArcGIS ModelBuilder实战:一键生成建筑矢量阴影,告别手动繁琐操作

ArcGIS ModelBuilder实战&#xff1a;一键生成建筑矢量阴影&#xff0c;告别手动繁琐操作 城市规划师小李最近接了个新项目——为某商业区绘制带阴影效果的建筑分布图。当他打开ArcGIS准备大展拳脚时&#xff0c;却发现手动创建建筑阴影的步骤繁琐得令人抓狂&#xff1a;每个建…...

SRS WebRTC部署踩坑实录:WHIP 404报错?可能是你的证书和端口配置错了

SRS WebRTC部署实战&#xff1a;WHIP 404报错深度排查指南 引言 当你满怀期待地按照官方文档部署SRS WebRTC服务&#xff0c;却在关键时刻遭遇WHIP接口404报错时&#xff0c;那种挫败感我深有体会。作为一名经历过多次类似问题的开发者&#xff0c;我理解这种看似简单却令人抓狂…...

QMCDecode macOS音频解密终极指南:3分钟学会QQ音乐加密格式破解

QMCDecode macOS音频解密终极指南&#xff1a;3分钟学会QQ音乐加密格式破解 【免费下载链接】QMCDecode QQ音乐QMC格式转换为普通格式(qmcflac转flac&#xff0c;qmc0,qmc3转mp3, mflac,mflac0等转flac)&#xff0c;仅支持macOS&#xff0c;可自动识别到QQ音乐下载目录&#xf…...

大语言模型长上下文处理能力评测框架LOCA-bench解析

1. 项目背景与核心价值最近在AI领域出现了一个很有意思的现象&#xff1a;大语言模型&#xff08;LLM&#xff09;的上下文窗口正在以惊人的速度扩张。从最初的几千token到现在的百万级上下文处理能力&#xff0c;这种进化带来了新的机遇和挑战。LOCA-bench正是在这样的背景下诞…...