Python Day8

@浙大疏锦行 PythonDay8.

内容:

  • 字典(字典对)
    *

    python 复制代码
    dict_test = dict(name='zhangsan', age=18)
  • 标签编码(离散特征 && 有顺序)

  • 连续特征的归一化和标准化处理

代码:

python 复制代码
# Question 1 dic
dict = {'Alice': 100, 'Bob': 200, 'Charlie': 300}

# Question 2 label-Code and 连续变量编码
import pandas as pd
import numpy as np

# 独热编码
def one_hot(data, columns):
    data = pd.get_dummies(data=data, columns=columns)
    return data
# 标签编码
def label_encoder(data, columns):
    if len(columns)  == 0:  # 处理异常情况
        return data
    value_index = list(range(len(columns))) # [1 2 3 4 5 6]
    mapping = dict(zip(columns, value_index))
    data[columns] = data[columns].map(mapping)
    return data
# 归一化
def min_max(data, columns):
    if len(columns)  == 0:  # 处理异常情况
        return data
    for column in columns:
        column_data = data[column]
        min_val = column_data.min()
        max_val = column_data.max()
        column_data = (column_data - min_val) / (max_val - min_val)
        data[column] = column_data
    return data

data = pd.read_csv("./data/heart.csv")
discrete_columns = []
continuous_columns = []
for column in data.columns:
    if data[column].dtype == 'object':
        discrete_columns.append(column)
    else:
        continuous_columns.append(column)

data = min_max(data, continuous_columns) # 归一化
# data = one_hot(data, discrete_columns) # 独热编码
data = label_encoder(data, discrete_columns) # 标签编码

print(data.head())
相关推荐
2301_764441331 小时前
Python管理咨询数据可视化实战:收入分布与顾问利用率双轴对比图表生成脚本
开发语言·python·信息可视化
该用户已不存在1 小时前
不知道这些工具,难怪的你的Python开发那么慢丨Python 开发必备的6大工具
前端·后端·python
Monkey的自我迭代2 小时前
Python标准库:时间与随机数全解析
前端·python·数据挖掘
SsummerC3 小时前
【leetcode100】下一个排列
python·算法·leetcode
Kelaru3 小时前
本地Qwen中医问诊小程序系统开发
python·ai·小程序·flask·project
Menger_Wen3 小时前
分析新旧因子相关性
python·机器学习·区块链
RAY_01044 小时前
Python—数据容器
开发语言·python
June bug4 小时前
【python基础】python和pycharm的下载与安装
开发语言·python·pycharm
im_AMBER5 小时前
python实践思路(草拟计划+方法)
开发语言·python
站大爷IP5 小时前
Python与JSON:结构化数据的存储艺术
python