Numpy(Pandas)删除全为零的列的方法


Posted in Python onSeptember 11, 2020

在处理numpy数组,有这个需求,故写下此文:

使用np.argwhere和np.all来查找索引。要使用np.delete删除它们。

示例1

import numpy as np
a = np.array([[1, 2, 0, 3, 0],
       [4, 5, 0, 6, 0],
       [7, 8, 0, 9, 0]])

idx = np.argwhere(np.all(a[..., :] == 0, axis=0))
a2 = np.delete(a, idx, axis=1)

print(a2)

"""
[[1 2 3]
 [4 5 6]
 [7 8 9]]
"""

示例2

import numpy as np

array1 = np.array([[1,0,1,0,0,0,0,0,0,1,1,0,0,0,1,1,0,1,0,0],
          [0,1,1,0,0,1,1,1,1,0,0,0,1,0,1,0,0,1,1,1],
          [0,0,1,0,0,1,1,1,0,0,0,0,0,0,0,1,0,0,1,1],
          [0,1,1,0,0,1,1,1,1,0,1,1,1,0,0,1,0,0,1,1],
          [0,0,1,0,0,1,1,1,0,1,0,1,1,0,1,1,0,0,1,0],
          [1,0,1,0,0,0,1,0,0,1,1,1,1,0,1,1,0,0,1,0],
          [1,0,1,0,1,1,0,0,0,0,1,0,0,0,1,0,0,0,1,1],
          [0,1,0,0,1,0,0,0,1,0,1,1,1,0,1,0,0,1,1,0],
          [0,1,0,0,1,0,0,1,1,0,1,1,1,0,0,1,0,1,0,0],
          [1,0,0,0,0,1,0,1,0,0,0,1,1,0,0,1,0,1,0,0]])

mask = (array1 == 0).all(0)
column_indices = np.where(mask)[0]
array1 = array1[:,~mask]

print("raw array", array1.shape)  # raw array (10, 20)
print("after array",array1.shape) # after array (10, 17)
print("=====x=====\n",array1)

其它查看:https://moonbooks.org/Articles/How-to-remove-array-rows-that-contain-only-0-in-python/

pandas 删除全零列

from pandas import DataFrame

df1=DataFrame(np.arange(16).reshape((4,4)),index=['a','b','c','d'],columns=['one','two','three','four'])   # 创建一个dataframe
df1.loc['e'] = 0          # 优雅地增加一行全0
df1.ix[(df1==0).all(axis=1), :]  # 找到它
df1.ix[~(df1==0).all(axis=1), :]  # 删了它

到此这篇关于Numpy(Pandas)删除全为零的列的方法的文章就介绍到这了,更多相关Numpy删除全为零的列内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!

Python 相关文章推荐
Linux下编译安装MySQL-Python教程
Feb 02 Python
Python中利用xpath解析HTML的方法
May 14 Python
Python爬虫框架scrapy实现downloader_middleware设置proxy代理功能示例
Aug 04 Python
Python开发虚拟环境使用virtualenvwrapper的搭建步骤教程图解
Sep 19 Python
基于Python3.6+splinter实现自动抢火车票
Sep 25 Python
Python assert关键字原理及实例解析
Dec 13 Python
python 读写文件包含多种编码格式的解决方式
Dec 20 Python
python设置环境变量的作用整理
Feb 17 Python
Matplotlib使用字符串代替变量绘制散点图的方法
Feb 17 Python
python实现批量转换图片为黑白
Jun 16 Python
使用keras实现BiLSTM+CNN+CRF文字标记NER
Jun 29 Python
详解python内置模块urllib
Sep 09 Python
详解Python中import机制
Sep 11 #Python
python使用隐式循环快速求和的实现示例
Sep 11 #Python
Python实现加密的RAR文件解压的方法(密码已知)
Sep 11 #Python
降低python版本的操作方法
Sep 11 #Python
Django crontab定时任务模块操作方法解析
Sep 10 #Python
Django日志及中间件模块应用案例
Sep 10 #Python
Django nginx配置实现过程详解
Sep 10 #Python
You might like
一个显示天气预报的程序
2006/10/09 PHP
提取HTML标签
2006/10/09 PHP
PHP中根据IP地址判断城市实现城市切换或跳转代码
2012/09/04 PHP
smarty中改进truncate使其支持中文的方法
2016/05/30 PHP
php中使用array_filter()函数过滤数组实例讲解
2021/03/03 PHP
Javascript里使用Dom操作Xml
2007/01/22 Javascript
jQuery.extend 函数详解
2012/02/03 Javascript
jquery判断小数点两位和自动删除小数两位后的数字
2014/03/19 Javascript
JavaScript实现同步于本地时间的动态时间显示方法
2015/02/02 Javascript
浅谈类似于(function(){}).call()的js语句
2015/03/30 Javascript
用原生js统计文本行数的简单示例
2016/08/19 Javascript
谈谈因Vue.js引发关于getter和setter的思考
2016/12/02 Javascript
详解Nodejs的timers模块
2016/12/22 NodeJs
React Router基础使用
2017/01/17 Javascript
JavaScript基本类型值-Number类型
2017/02/24 Javascript
JavaScript之Map和Set_动力节点Java学院整理
2017/06/29 Javascript
layui中layer前端组件实现图片显示功能的方法分析
2017/10/13 Javascript
解决vue build打包之后首页白屏的问题
2018/03/06 Javascript
前端Electron新手入门教程详解
2019/06/21 Javascript
JS实现返回上一页并刷新页面的方法分析
2019/07/16 Javascript
js实现点赞按钮功能的实例代码
2020/03/06 Javascript
解决Vue router-link绑定事件不生效的问题
2020/07/22 Javascript
python del()函数用法
2013/03/24 Python
Python兔子毒药问题实例分析
2015/03/05 Python
Python中列表和元组的使用方法和区别详解
2020/12/30 Python
Python双精度浮点数运算并分行显示操作示例
2017/07/21 Python
实践Vim配置python开发环境
2018/07/02 Python
Python for循环与range函数的使用详解
2019/03/23 Python
python实现两张图片拼接为一张图片并保存
2019/07/16 Python
Python importlib动态导入模块实现代码
2020/04/16 Python
英国电视和家用电器购物网站:rlrdistribution.co.uk
2018/11/20 全球购物
美国领先的机场停车聚合商:Airport Parking Reservations
2020/02/28 全球购物
2014村务公开实施方案
2014/02/25 职场文书
新闻专业毕业生求职信
2014/08/08 职场文书
表扬信格式模板
2015/05/05 职场文书
mysql事务对效率的影响分析总结
2021/10/24 MySQL