pandas骚操作:分组对数据进行归一化

import pandas as pd
import  numpy as np


data = pd.read_csv('zhenjiang_power.csv')  # 读取负荷
data.loc['record_date']=pd.to_datetime(data['record_date'])#将record_date转换为时间格式

print('data\n',data)

# 实现按照用户ID分组,然后对其中一列映射到0-1区间
def ratings_norm(df):
    """
    @param df:每个用户分组的dataframe
    """
    min_value = df["power_consumption"].min()
    max_value = df["power_consumption"].max()
    MIN=0
    MAX=1
    df["Rating_norm"] = df["power_consumption"].apply(
        lambda x: MIN+(MAX-MIN)/(1+max_value-min_value)*(x-min_value))
    return df
    #(1+max_value-min_value) 为了防止分母为0的情况出现


ratings = data.groupby("user_id").apply(ratings_norm)

print('----11111111111111111-----')
print('ratings\n',ratings)

在这里插入图片描述

作者:电气 余登武

  • 2
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

总裁余(余登武)

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值