python离散化方法_python中字符串离散化的例子

'''

问题:

1、假设DataFrame中有一列名为type,其字段中内容为a,b,c 等用,隔开的值,如:

type

a,b,c

a,f,x

b,c,e

...

统计type中每个类型出现的次数 并绘图

'''

import pandas as pd

import numpy as np

from matplotlib import pyplot as plt

# 读取数据

df = pd.read_csv("文件路径/文件名")

#统计分类的列表

temp_list = df["type"].str.split(",").tolist()

type_list = list(set([i for j in temp_list for i in j]))

# 构造全为0的数组

zeros_df = pd.DataFrame(np.zeros((df.shape[0],len(type_list))),columns=type_list)

# print(zeros_df)

# 给每个type出现分类的位置赋值为1

for i in range(df.shape[0]):

zeros_df.loc[i,temp_list[i]] = 1

# 统计每个分类type的数量和

type_count = zeros_df.sum(axis=0)

print(type_count)

# 排序

type_count = type_count.sor_values()

_x = type_count.index

_y = type_count.values

# 绘图

# 设置图片大小

plt.figure(figsize=(20,8),dpi=80)

plt.bar(range(len(_x)),_y) #绘制条形图

plt.xticks(range(_x),_x)

plt.show()

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值