首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

学徒讨论-在数据框里面使用每列的平均值替换NA

最近学徒群在讨论一个需求,就是用数据框的每一列的平均数替换每一列的NA值。但是问题的提出者自己的代码是错的,如下: ? 他认为替换不干净,应该是循环有问题。...#我好像试着写出来了,上面的这个将每一列的NA替换成每一列的平均值。 #代码如下,请各位老师瞅瞅有没有毛病。...所以我在全局环境里面设置了一个空的list,然后每一列占据了list的一个元素的位置。list的每个元素里面包括了NA的横坐标。...答案二:使用Hmisc的impute函数 我给出的点评是:这样的偷懒大法好!使用Hmisc的impute函数可以输入指定值来替代NA值做简单插补,平均数、中位数、众数。...a=1:1000 a[sample(a,100)]=NA dim(a)=c(20,50) a # 按照列,替换每一列的NA值为该列的平均值 b=apply(a,2,function(x){ x[is.na

3.6K20
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    独家 | PySpark和SparkSQL基础:如何利用Python编程执行Spark(附代码)

    通过名为PySpark的Spark Python API,Python实现了处理结构化数据的Spark编程模型。 这篇文章的目标是展示如何通过PySpark运行Spark并执行常用函数。...最简单的方式是通过Anaconda使用Python,因其安装了足够的IDE包,并附带了其他重要的包。 1、下载Anaconda并安装PySpark 通过这个链接,你可以下载Anaconda。...在本文的例子中,我们将使用.json格式的文件,你也可以使用如下列举的相关读取函数来寻找并读取text,csv,parquet文件格式。...5.2、“When”操作 在第一个例子中,“title”列被选中并添加了一个“when”条件。...10、缺失和替换值 对每个数据集,经常需要在数据预处理阶段将已存在的值替换,丢弃不必要的列,并填充缺失值。pyspark.sql.DataFrameNaFunction库帮助我们在这一方面处理数据。

    13.7K21

    spark 数据处理 -- 数据采样【随机抽样、分层抽样、权重抽样】

    定量调查中的分层抽样是一种卓越的概率抽样方式,在调查中经常被使用。 选择分层键列,假设分层键列为性别,其中男性与女性的比例为6:4,那么采样结果的样本比例也为6:4。...权重采样 选择权重值列,假设权重值列为班级,样本A的班级序号为2,样本B的班级序号为1,则样本A被采样的概率为样本B的2倍。....html from pyspark.sql.functions import lit list = [(2147481832,23355149,1),(2147481832,973010692,1),...https://www.codenong.com/44352986/ SMOT 过采样 针对类别不平衡的数据集,通过设定标签列、过采样标签和过采样率,使用SMOTE算法对设置的过采样标签类别的数据进行过采样输出过采样后的数据集..._jdf.sample(*args) return DataFrame(jdf, self.sql_ctx) 根据每个层上给定的分数返回分层样本,不进行替换。

    6.4K10

    【干货】Python大数据处理库PySpark实战——使用PySpark处理文本多分类问题

    【导读】近日,多伦多数据科学家Susan Li发表一篇博文,讲解利用PySpark处理文本多分类问题的详情。我们知道,Apache Spark在处理实时数据方面的能力非常出色,目前也在工业界广泛使用。...本文通过使用Spark Machine Learning Library和PySpark来解决一个文本多分类问题,内容包括:数据提取、Model Pipeline、训练/测试数据集划分、模型训练和评价等...并展示前五行: drop_list = ['Dates', 'DayOfWeek', 'PdDistrict', 'Resolution', 'Address', 'X', 'Y'] data = data.select...([column for column in data.columns if column not in drop_list]) data.show(5) ?...明显,我们会选择使用了交叉验证的逻辑回归。

    26.2K5438

    PySpark初级教程——第一步大数据分析(附代码实现)

    在这种情况下,你需要使用构建工具。 SBT是Scala构建工具的缩写,它管理你的Spark项目以及你在代码中使用的库的依赖关系。 请记住,如果你使用的是PySpark,就不需要安装它。...设置Spark环境变量 使用下面的命令打开并编辑bashrc文件。...在第一步中,我们创建了一个包含1000万个数字的列表,并创建了一个包含3个分区的RDD: # 创建一个样本列表 my_list = [i for i in range(1,10000000)] # 并行处理数据...在稀疏矩阵中,非零项值按列为主顺序存储在压缩的稀疏列格式(CSC格式)中。...# 导入矩阵 from pyspark.mllib.linalg import Matrices # 创建一个3行2列的稠密矩阵 matrix_1 = Matrices.dense(3, 2, [1,2,3,4,5,6

    4.5K20

    3万字长文,PySpark入门级学习教程,框架思维

    1)要使用PySpark,机子上要有Java开发环境 2)环境变量记得要配置完整 3)Mac下的/usr/local/ 路径一般是隐藏的,PyCharm配置py4j和pyspark的时候可以使用 shift...下面是一些示例demo,可以参考下: 1)Mac下安装spark,并配置pycharm-pyspark完整教程 https://blog.csdn.net/shiyutianming/article/details...创建SparkDataFrame 开始讲SparkDataFrame,我们先学习下几种创建的方法,分别是使用RDD来创建、使用python的DataFrame来创建、使用List来创建、读取数据文件来创建...使用List来创建 list_values = [['Sam', 28, 88], ['Flora', 28, 90], ['Run', 1, 60]] Spark_df = spark.createDataFrame...原算子 高效算子(替换算子) 说明 map mapPartitions 直接map的话,每次只会处理一条数据,而mapPartitions则是每次处理一个分区的数据,在某些场景下相对比较高效。

    10K21

    PySpark SQL——SQL和pd.DataFrame的结合体

    1)创建DataFrame的方式主要有两大类: 从其他数据类型转换,包括RDD、嵌套list、pd.DataFrame等,主要是通过spark.createDataFrame()接口创建 从文件、数据库中读取创建...,并制定不同排序规则 df.sort(['age', 'name'], ascending=[True, False]).show() """ +----+---+-------------------...并返回新的DataFrame(包括原有其他列),适用于仅创建或修改单列;而select准确的讲是筛选新列,仅仅是在筛选过程中可以通过添加运算或表达式实现创建多个新列,返回一个筛选新列的DataFrame...action算子,即会真正执行计算并返回结果;而前面的很多操作则属于transform,仅加入到DAG中完成逻辑添加,并不实际执行计算 take/head/tail/collect:均为提取特定行的操作...hour提取相应数值,timestamp转换为时间戳、date_format格式化日期、datediff求日期差等 这些函数数量较多,且与SQL中相应函数用法和语法几乎一致,无需全部记忆,仅在需要时查找使用即可

    10K20

    Spark Extracting,transforming,selecting features

    CountVectorizer和CountVectorizerModel的目标是将文本文档集合转换为token出行次数的向量,当一个先验的词典不可用时,CountVectorizr可以作为一个预测器来提取词汇并生成...,这种编码使得那些期望输入为数值型特征的算法,比如逻辑回归,可以使用类别型特征; from pyspark.ml.feature import OneHotEncoder, StringIndexer...假设我们有下列DataFrame: a b 1.0 Double.NaN 2.0 Double.NaN Double.NaN 3.0 4.0 4.0 5.0 5.0 在这个例子中,Imputer会替换所有...Double.NaN为对应列的均值,a列均值为3,b列均值为4,转换后,a和b中的NaN被3和4替换得到新列: a b out_a out_b 1.0 Double.NaN 1.0 4.0 2.0 Double.NaN...LSH family,杰卡德距离的定义是两个集合的交集和并集的基数: d(\mathbf{A}, \mathbf{B}) = 1 - \frac{|\mathbf{A} \cap \mathbf{B}

    21.9K41
    领券