python机器学习随笔

1.scikit-learn数据集API介绍
·sklearn.datasets 加载获取流行数据集
datasets.load_*() 获取小规模数据集,数据集包含在datasets里
datasets.fetch_*() 获取大规模数据集,需要从网络上下载,函数的第一个参数是data_home,表示数据集下载的目录,
默认~/scikit_learn_data/
2.sklearn小数据集
·sklearn.datasets.load_iris() 加载并返回鸢尾花
·sklearn.datasets.load_boston()加载并返回波士顿房价数据集
3.数据集的返回值
·datasets.base.Bunch(继承自字典)
dict["key"] = values
dict.key = values


特征工程(Feature Engineering)
sklearn 特征工程
pandas数据清洗 ,数据处理

#####特征抽取/特征提取#######

特征提取API
·字典特征提取(特征离散化)
·文本特征提取
·图像特征提取
sklearn.feature_extraction

·字典特征提取
sklearn.feature_extraction.DictVectorizer(sparse=True)
DictVectorizer.fit_transform(X) X:字典或者包含字典的迭代器返回值:返回sparse矩阵
sparse表示稀疏矩阵
将非零值 按位置表示出来
节省内存 提高加载效率
DictVectorizer.inverse_transform(X) X:array数组或者sparse矩阵 返回值:转换之前数据格式
DictVectorizer.get_feature_names() 返回类别名称
总结:对于特征当中存在类别信息我们都会做one-hot编码处理(不区分优先级)
应用场景:
1.pclass,sex 数据集当中特征值比较多
DictVectorizer转换
2.本身拿到的数据就是字典类型

·文本特征提取
单词 作为 特征
句子、短语、字母、单词都可以作为特征
特征:特征词
方法1:CountVectorizer(stop_words=[])
stop_words停用词
停用词表
CountVectorizer.fit_transform(X) X:文本或者包含文本字符串的可迭代对象 返回值:返回sparse矩阵
CountVectorizer.inverse_transform(X) X:array数组或者sparse矩阵 返回值:转换之前数据格
CountVectorizer.get_feature_name() 返回值:单词列表
关键词:在某一个类别的文章中,出现次数很多,但是在其他类别的文章当中出现很少
方法2:TfidfVectorizer
TF-IDF 重要程度
两个词 “经济”,“非常”
1000篇文章-语料库
100篇文章-“非常”
10篇文章-“经济”
两篇文章
文章A(100词):10次“经济”TF-IDF=0.2
tf = 10/100 = 0.1 IDF=lg(1000/10)=2

文章B(100词):10次“非常”TF-IDF=0.1
tf = 10/100 = 0.1
TF -词频(term frequency) IDF=lg(1000/100)=1
IDF-逆向文档频率


####数据预处理#####
无量纲化
·归一化:通过原始数据进行变换把数据映射到(默认为[0,1])之间
·sklearn.preprocessing.MinMaxScaler(feature_range=(0,1)...)
MinMaxScalar.fit_transform(X)
X:numpy array格式的数据[n_samples,n_features] 参数为 行 列
·标准化:通过对原始数据进行变换把数据变换到均值为0,标准差为1的范围内
(x-mean)/std
标准差:集中程度
·sklearn.preprocessing.StandardScaler()
StandardScaler.fit_transform(X)
·降维 ndarray
维数:嵌套的层数 0维-标量 1维-向量 2维-矩阵
此处的降维:降低特征(随机变量)的个数
效果:特征与特征之间不相关
·特征选择
Filter过滤式
方差选择发:低方差特征过滤 方差小:某个特征大多样本的值比较相近

·sklearn.feature_selection.VarianceThreshold(threshold = 0.0)
·删除所有低方差特征
·Variance.fit_transform(X)
X:numpy array格式的数据[n_samples,n_features]
返回值:训练集差异低于threshold的特征将被删除。默认值是保留所有
非零方差特征。即删除所有相同的特征值

相关系数-衡量特征与特征之间的相关程度
皮尔逊相关系数
Embeded嵌入式
决策树
正则化
深度学习

·主成分分析:高维数据转化为低维数据的过程中可能会舍弃原有数据、创造新的变量
是数据维度压缩,尽可能降低原数据的维度(复杂性),损失少量信息
应用:回归分析或者聚类分析当中
·sklearn.decomposition.PCA(n_components=None)
·将数据分解为较低维度空间
·n_components:小数:表示保留百分之多少的信息
整数;减少到多少特征 如二维n_components=2
·PCA.fit_transform(X) X:numpy array格式数据 [n_samples,n_features]
·返回值:转换后指定维度的array

案例:探究用户对物品类别的喜好细分
用户 物品类别
user_id aisle_id
见jupyter notebook

from sklearn.datasets import load_iris
from sklearn.model_selection import train_test_split
from sklearn.preprocessing import StandardScaler
from sklearn.neighbors import KNeighborsClassifier
from sklearn.model_selection import GridSearchCV

def knn_iris():
    """
    用KNN算法对鸢尾花进行分类
    :return:
    """
    #1)获取数据
    iris = load_iris()
    #2)划分数据集
    x_train,x_test,y_train,y_test = train_test_split(iris.data,iris.target,random_state=6)

    #3)特征工程:标准化
    transfer = StandardScaler()
    x_train= transfer.fit_transform(x_train)#训练集

    x_test = transfer.transform(x_test)
    #用训练集的标准差和平均值做标准化 transform的作用是根据找到的规则对数据进行转换

    #4)KNN算法预估器
    estimator = KNeighborsClassifier(n_neighbors=3)
    estimator.fit(x_train,y_train)
    #5)模型评估
    #方法1:直接比对真实值和预测值
    y_predict = estimator.predict(x_test)
    print("y_predict:\n",y_predict)
    print("直接比对真实值和预测值:\n",y_test == y_predict)

    #方法2:计算准确率
    score= estimator.score(x_test,y_test)
    print("准确率为:\n",score)
    return None
def knn_iris_gscv():
    """
    用KNN算法对鸢尾花进行分类,添加网格搜索和交叉验证
    :return:
    """
    #1)获取数据
    iris = load_iris()
    #2)划分数据集
    x_train,x_test,y_train,y_test = train_test_split(iris.data,iris.target,random_state=6)

    #3)特征工程:标准化
    transfer = StandardScaler()
    x_train= transfer.fit_transform(x_train)#训练集

    x_test = transfer.transform(x_test)
    #用训练集的标准差和平均值做标准化 transform的作用是根据找到的规则对数据进行转换

    #4)KNN算法预估器
    estimator = KNeighborsClassifier()
    #加入网格搜索与交叉验证
    #参数准备
    param_dict= {"n_neighbors":[1,3,5,7,9,11]}
    estimator  = GridSearchCV(estimator,param_grid=param_dict,cv = 10)


    estimator.fit(x_train,y_train)
    #5)模型评估
    #方法1:直接比对真实值和预测值
    y_predict = estimator.predict(x_test)
    print("y_predict:\n",y_predict)
    print("直接比对真实值和预测值:\n",y_test == y_predict)

    #方法2:计算准确率
    score= estimator.score(x_test,y_test)
    print("准确率为:\n",score)

    # ·最佳参数:best_params_
    print("最佳参数:\n",estimator.best_params_)
    # ·最佳结果:best_score_
    print("最佳结果:\n",estimator.best_score_)
    # ·最佳估计器:best_estimator_
    print("最佳估计器:\n",estimator.best_estimator_)
    # ·交叉验证结果:cv_results_
    print("交叉验证结果:\n",estimator.cv_results_)
    return None
if __name__ =="__main__":
    #代码1:用KNN算法对鸢尾花进行分类
    # knn_iris()
    knn_iris_gscv()

jupyter notebook

#1.获取数据
#2.合并表
#3.找到user_id和aisle之间的关系
#4.PCA降维
import pandas as pd

order_products = pd.read_csv("./instacart/order_products_prior.csv")
products = pd.read_csv("./instacart/products.csv")
orders = pd.read_csv("./instacart/orders.csv")
aisles = pd.read_csv("./instacart/aisles.csv")

#2.合并表

#合并aisles和products ,让aisle和product_id在一起
tab1 = pd.merge(aisles,products,on=["aisle_id","aisle_id"])

tab2 = pd.merge(tab1,order_products,on=["product_id","product_id"])

tab3 = pd.merge(tab2,orders,on=["order_id","order_id"])

#3.找到user_id和aisle之间的关系
table = pd.crosstab[tab3["user_id"],tab3["aisle"]]

#4.PCA降维
from sklearn.decomposition import PCA

#1.实例化一个转换器
transfer = PCA(n_components = 0.95) #保存95%的信息

#2.调用fit_transform
data_new = transfer.fit_transform(data)

 

posted @ 2019-02-17 19:26  顾本无缘  阅读(363)  评论(0编辑  收藏  举报