数据挖掘-数据

数据的描述

import warnings
warnings.filterwarnings("ignore")
import pandas as pd
db = pd.read_excel('model.xls')
# 数据前5行
db.head()
# 数据的信息,缺省值,类型,行,列
db.info()
# 数据的基本统计描述
db.describe()
# 数据的缺失值
db.apply(lambda x: sum(x.isnull()))
# 第几列值出现的次数
db.ix[:,[30]].apply(pd.value_counts)
# 每一列值出现的次数
for x in range(31):
    print(db.ix[:,[x]].apply(pd.value_counts))
# 数据的分布图 最多9个
import matplotlib.pyplot as plt
import seaborn as sns
# 画图字体乱码
plt.rcParams['font.sans-serif'] = ['SimHei'] # 步骤一(替换sans-serif字体)
plt.rcParams['axes.unicode_minus'] = False  
plt.figure(figsize=(30, 30))
a = 1
for val in db.ix[:,[x for x in range(9)]].columns:
    if str(db[val].dtype) == 'int32' or str(db[val].dtype) == 'int64' or str(db[val].dtype) == 'float64':
        if db.shape[1] >= 3:
            try:
                b = "33" + str(a)
                plt.subplot(int(b))
                sns.distplot(db[val])
                a = a + 1
            except:
                print("%s里面有全部一个值的"%val)
        else:
            plt.subplot(int(str(1) + str(db.shape[1]) + str(a)))
            sns.distplot(db[val])
            a = a + 1
plt.show()

数据的噪声--错误,异常,不确定性,缺失

# 缺失值的处理,若此列缺值太多,可放弃
# 1 拿平均值填充
from sklearn import preprocessing
impute = preprocessing.Imputer()
iris_X_prime = impute.fit_transform(iris_X)
iris_X_prime[:5]
#上面的计算可以通过不同的方法实现。默认是均值mean,一共是三种:

#均值mean(默认方法)
#中位数median
#众数most_frequent

iris_df.fillna(iris_df.mean())['sepal length (cm)'].head(5)

数据属性--标称属性(多类,可枚举的)
二元属性(0,1)
序数属性(逐渐进阶的那种,出生-生长-老去-死了,有步骤的)
数值属性(整数或者是实数值表示,看是否连续或者是离散(离散值是有限的)
连续值是可以转换成离散

数据属性--类别(object)

# 数据类别转换,类别编码0,1,2,3
from sklearn.preprocessing import LabelEncoder
class_le = LabelEncoder()
#用class_le.fit_transform将其转换
data_label_num.iloc[:,0] = class_le.fit_transform(data_label_num.iloc[:,0].values)



# One-hot编码
from sklearn.preprocessing import OneHotEncoder
#True 则返回一个array, False 则返回matrix矩阵
onehot_age = OneHotEncoder(sparse=False).fit_transform(data[['age']])

数据属性--数值(float,int)

# 数据标准化
from sklearn.preprocessing import StandardScaler
std = StandardScaler()
# 对训练集进行标准化操作
#最后的结果均值为0,方差是1,从公式就可以看出。
#但是当原始数据并不符合高斯分布的话,标准化后的数据效果并不好。适用于连续值
x_train = std.fit_transform(db)
x_train



# 数据变换
k = 4 #等宽法 
#基于聚类分析的方法 
from sklearn.cluster import KMeans 
#引入KMeans 
kmodel = KMeans(n_clusters = k, n_jobs = 4) 
#建立模型,n_jobs是并行数,一般等于CPU数较好 
kmodel.fit(c.values, 1) 
#训练模型 
e = pd.DataFrame(kmodel.cluster_centers_).sort_values(0) 
#输出聚类中心,并且排序(默认是随机序的)
print(e)
w = e.rolling(2).mean().iloc[1:] 
print(w)
#相邻两项求中点,作为边界点 
w = w.values.tolist()
cmax = c.max().tolist()
print(cmax)
print(w)
g=[0]
for x in w:
    g.append(x[0])
g.append(cmax[0])
print(g)
#把首末边界点加上,w[0]中0为列索引 
a = c.values.tolist()
#print(a)
u=[]
for x in a:
    u.append(x[0])
print(u)

# 利用pandas cut函数
d3 = pd.cut(u, g, )
print(d3)

数据规约
pca主成分分析

特征选择--过滤型(移除低方差的特征,卡方检验),包裹型,嵌入型(基于树模型的特征选择)

#方差选择法,返回值为特征选择后的数据
#参数threshold为方差的阈值
VarianceThreshold(threshold=3).fit_transform(iris.data)

#选择K个最好的特征,返回选择特征后的数据 卡方检验
data = SelectKBest(chi2, k=2).fit_transform(iris.data, iris.target)




#基于树模型的特征选择
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,233评论 6 495
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,357评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,831评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,313评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,417评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,470评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,482评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,265评论 0 269
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,708评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,997评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,176评论 1 342
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,827评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,503评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,150评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,391评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,034评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,063评论 2 352

推荐阅读更多精彩内容

  • 本文您将要了解: 1、数据由什么类型的属性或字段组成? 2、每个属性具有何种类型的数据值? 3、哪些属性是离散的?...
    Mickey_Q阅读 3,038评论 0 0
  • 单选题 1. 某超市研究销售纪录数据后发现,买啤酒的人很大概率也会购买尿布,这种属于数据挖掘的哪类问题?(A) A...
    山的那边是什么_阅读 33,542评论 2 59
  • 分类--逻辑回归,朴素贝叶斯,决策树,随机森林,GDBT,XGBoost 分类评估--正确率,精度,召回率,F1值...
    紫弟阅读 538评论 0 0
  • TOP1狮子座:喜欢赢的感觉 狮子座天生的自尊心作祟,游戏中不仅仅喜欢赢还喜欢众人膜拜他的感觉!走位好威风!操作好...
    电娱时代阅读 254评论 0 0
  • 从前,我相信眼缘 一眼,纠缠成缘 好多年,我渐渐擦掉许多怀念 剩下浅浅的痕迹蔓延 等到人事消散,你终是不在 我等从...
    执迷不悟赵先生阅读 194评论 0 0