一、numpy

  numpy是python数据分析和机器学习的基础模块之一。它有两个作用:1.区别于list列表,提供了数组操作、数组运算、以及统计分布和简单的数学模型;2.计算速度快[甚至要由于python内置的简单运算],使得其成为pandas、sklearn等模块的依赖包。高级的框架如TensorFlow、PyTorch等,其数组操作也和numpy非常相似。

  1、随机数生成

    常用的生成随机数的几个函数:

    

li = list(range(10))
print(li, type(li)) li = np.array(li)
print(li, type(li)) li = li.tolist() # list(li)也可以
print(li, type(li))

list和array互相转化

np.random.rand(10, 5)   # 生成[0, 1]之间均匀分布的数组10行,5列

np.random.randn(10, 5)  # 生成[0, 1]之间均匀分布的数组10行,5列

np.random.randint(10, 20, size=(10, 5))  #  生成[10, 20]之间随机数组10行,5列

np.random.random(size=(10, 5))  # 生成[0, 1]之间的10行5列的数组

li = list(range(10))
np.random.choice(li, size=(10, 5)) # 从li中产生随机数,生成10行5列的数组 np.arange(10, 20, 2, ) # 从[10, 20]中以步长为2生成一维数组

函数使用

     其它不常见的随机数生成函数:

    

np.random.binomial(100, 0.5, size=(10, 5))

二项分布

  2、数组切片

   array对象的切片和list列表的切片操作相同。记住一个规则array[start: end: step]。

dt = np.random.binomial(100, 0.5, size=(10, 5))
dt[1: 3, :]
dt[[1,5], :]
dt[[1, 4, 7]]
dt[:, [2, 4]]

数组切片

   一维和n维数组的转化

li = np.random.random((1, 100)).reshape(20, 5)   # 将1行100列的数组转换成20行5列的新数组
print(li) li = li.reshape((2, -1)) # 将20行5列的数组转换成2行50列的新数组
# 将20行5列的数组转换为2行50列的数组,-1表示根据原数据和当前行[列]参数来自动生成列[行]数
print(li) li = li.reshape(-1, 100) # 将2行50列的数组转换成1行100列的数组
print(li)

数组维度转化

  3、数组运算

# 加法
np.sum(l1) # 有意思的sum
np.sum(l1, axis=0)
np.sum(l1, axis=1)
np.sum([l1, l2])
np.subtract(l1, l2) # 减法
np.multiply(l1, l2) # 乘法
np.divide(l1, l2) # 除法
np.power(l1, l2) # 幂乘
np.floor_divide(l1, l2) # 地板除
np.floor(l1) # 向下取整
np.ceil(l1) # 向上取整
np.dot(l1, l2.T) # 点积 l2.T表示转置
np. # 以下和sum的使用方式相同
np.max(l1)
np.min(l1)
np.mean(l1)
np.median(l1)
np.std(l1)
np.var(l1)
# np.vander() # 必须是一维数组,
# li = np.arange(1, 5, step=1, dtype=int)
# np.vander(li, len(li))

  numpy还有其它的一些常用函数,如np.exp(), np.abs()等,也可以通过np.loadtxt读取txt文件。

  4、数组拼接

l1 = np.linspace(10, 20, num=72).reshape(12, 6)
l2 = np.random.random(size=(12, 6)) np.vstack((l1, l2)) # 按列拼接
np.hstack((l1, l2)) # 按行拼接 np.vsplit(l1, [3, 6, 9]) # 按行切割,参数3, 6, 9表示在第几行切割一下[包括这一行],生成一个list对象
np.hsplit(l1, [1, 3,]) # 按列切割

二、pandas

  官方api: http://pandas.pydata.org/pandas-docs/stable/api.html#general-functions

  pandas是python数据分析的核心模块。它主要提供了五大功能:

    - 1.支持文件存取操作,支持数据库(sql)、html、json、pickle、csv(txt、excel)、sas、stata、hdf等。

    - 2.支持增删改查、切片、高阶函数、分组聚合等单表操作,以及和dict、list的互相转换。

    - 3.支持多表拼接合并操作。

    - 4.支持简单的绘图操作。

    - 5.支持简单的统计分析操作。

  1、创建和存取pandas对象

dic = [
{
"name": "Li",
"age": 18,
"gender": "male"
},
{
"name": "Wusir",
"age": 16,
"gender": "female",
}
] df = pd.DataFrame(
data=dic,
index=None,
columns=["name", "age", "gender"], # list(dic.keys()),
dtype=None, # dtype不可用列表去给每个column去定义
)

字典创建

lis = np.random.random(size=(13, 5))
index = pd.period_range(start="2017-01-01", end="2018-01-01", freq="M")
# index = pd.period_range(start=pd.Period('2017Q1', freq='Q'), end=pd.Period('2017Q2', freq='Q'), freq='M')
df= pd.DataFrame(lis, index=index, columns=list("ABCED")).reset_index(drop=False)

数组创建

df.to_csv("test", header=True, index=False)
pd.read_csv("test")

保存成csv

import pandas as pd
import threading
import sqlalchemy
from sqlalchemy import create_engine engine = create_engine(
"mysql+pymysql://root:1234@127.0.0.1:3306/test?charset=utf8",
max_overflow=5,
pool_size=10,
pool_timeout=30,
pool_recycle=-1,
) df = pd.read_sql_table("test1", con=engine, columns=None)

读取一张table

import numpy as np
import pandas as pd
import pymysql def conn(sql):
# 连接到mysql数据库
conn = pymysql.connect(
host="localhost",
port=3306,
user="root",
passwd="",
db="test",
)
try:
data = pd.read_sql(sql, con=conn)
return data
except Exception as e:
print("SQL is not correct!", sep="\r\n\r\n")
finally:
conn.close() sql = "select * from test1 limit 0, 10" # sql语句
data = conn(sql)
# print(data.columns.tolist()) # 查看字段
print(data) # 查看数据

读取sql语句

    使用的数据文件为: https://files.cnblogs.com/files/kuaizifeng/test.zip

  2、切片与增删改查

    待续。。。。。。

    

    

python模块之numpy与pandas的更多相关文章

  1. python模块之numpy,pandas基本用法

    numpy: 是 Python 的一个扩展程序库,支持大量的维度数组与矩阵运算,此外也针对数组运算提供大量的数学函数库简单来说:就是支持一维数组和多维数组的创建和操作,并有丰富的函数库. 直接看例子 ...

  2. python模块之numpy

    Numpy是一个第三方库,是数组相关的运算 通过pip安装:pip install numpy Anaconda python的一个科学计算发行版本,安装后将不必单独安装numpy,下面的库模块也将不 ...

  3. day18-常用模块III (numpy、pandas、matplotlib)

    目录 numpy模块 创建矩阵 获取矩阵的行列数 切割矩阵 矩阵元素替换 矩阵的合并 通过函数创建矩阵 矩阵的运算 矩阵的点乘与转置 矩阵的逆 矩阵的其他操作 numpy.random生成随机数 pa ...

  4. python安装numpy和pandas

    最近要对一系列数据做同比比较,需要用到numpy和pandas来计算,不过使用python安装numpy和pandas因为linux环境没有外网遇到了很多问题就记下来了.首要条件,python版本必须 ...

  5. [转] python安装numpy和pandas

    最近要对一系列数据做同比比较,需要用到numpy和pandas来计算,不过使用python安装numpy和pandas因为linux环境没有外网遇到了很多问题就记下来了.首要条件,python版本必须 ...

  6. Python入门之安装numpy和pandas

    最近要对一系列数据做同比比较,需要用到numpy和pandas来计算,不过使用python安装numpy和pandas因为linux环境没有外网遇到了很多问题就记下来了. 首要条件,python版本必 ...

  7. 【转载】python安装numpy和pandas

    转载:原文地址 http://www.cnblogs.com/lxmhhy/p/6029465.html 最近要对一系列数据做同比比较,需要用到numpy和pandas来计算,不过使用python安装 ...

  8. 101道Numpy、Pandas练习题

    无论是数据分析还是机器学习,数据的预处理必不可少. 其中最常用.最基础的Python库非numpy和pandas莫属,很多初学者可能看了很多教程,但是很快就把用法忘光了. 光看不练假把式,今天向大家推 ...

  9. Python之路-numpy模块

    这里是首先需要安装好Anaconda Anaconda的安装参考Python之路-初识python及环境搭建并测试 配置好环境之后开始使用Jupyter Notebook 1.打开cmd,输入 jup ...

随机推荐

  1. 编程大牛 Bruce Eckel 对新程序员的忠告

    简评:作者 Bruce Eckel 是编程界的大牛,著有大名鼎鼎的<Thinking in C++>和<Thinking in Java>.本文是他对程序员(尤其是新手)的忠告 ...

  2. Android-获取手机已经安装的程序

    有时候我们会查询手机里面是否安装了某个程序,或者获取已经安装软件名称的集合. android这边提供了相应的接口. [java] view plaincopy final PackageManager ...

  3. Linux C 重定向简单范例

    //前言:我们知道printf()会将信息输出到stdout流,然后展示到屏幕上. //那么我们所实现的简单的重定向就可以将stdout指向一个文件,然后读写,这样就达到了重定向的目的. //code ...

  4. 原 form 表单中 disabled 属性的元素不参与表单提交

    https://blog.csdn.net/benben683280/article/details/79173336

  5. Python【每日一问】16

    问: [基础题]TCP/UDP/HTTP协议区别 [提高题]在一个二维数组中,每一行都按照从左到右递增的顺序排序,每一列都按照从上到下递增的顺序排序.请完成一个函数,输入这样的一个二维数组和一个整数, ...

  6. vue 在 html 中自定义 tag

    v-if,v-for,:key,:style,v-text,@click,:src,:poster,:class,:href

  7. 洛谷 P1273 有线电视网(树形背包)

    洛谷 P1273 有线电视网(树形背包) 干透一道题 题面:洛谷 P1273 本质就是个背包.这道题dp有点奇怪,最终答案并不是dp值,而是最后遍历寻找那个合法且最优的\(i\)作为答案.dp值存的是 ...

  8. Android之build.prop属性详解

    注:本篇文章是基于MSD648项目(AndroidTV)的prop进行说明. Android版本:4.4.4 内核版本:3.10.86 1.生成build.prop build.prop的生成是由ma ...

  9. 四、OE 中添加对供应商名称的唯一限制

    最初的思路是利用sql_constraints 来限制重复的供应商名称,但后来想到在OE中供应商.客户乃至员工都隶属于Partner,sql_constrainst实际上是通过限制partner来限制 ...

  10. Yii 使用Widge面面观

    我们可以把Widget视为一个嵌入到控制器管理 的视图中的微控制器,其实就是.net框架中的用户控件,或者类似于.net MVC中的子视图.与controller相比较,微件没有既没有动作,也没有过滤 ...