我的python学习笔记(3) numpy

时间有限,行文仓促,代码在https://github.com/bentan2013/PythonAndGIS/blob/master/numpy/basic.ipynb


为什么用numpy?

  • 支持多维数组
  • 自身支持多种矩阵运算
  • 可以和机器学习的各种开源框架的tensor相互转化

numpy的安装?

安装完pip,就可以使用pip install numpy
 
 

numpy基础

使用之前需要先引用包
import numpy as np
之后就可以使用np.somefunction()来引用其中的函数,数据结构了。
 

创建方式

可以从列表生成,数组生成,插值生成,生成格网,随机初始化,初始化为0或者1
#从列表生成
tmp = np.array([1,2,3])

数组为:
[1 2 3]

#插值生成 linspace logspace
mat = np.linspace(0, 18, 9)
mat: array([  0.  ,   2.25,   4.5 ,   6.75,   9.  ,  11.25,  13.5 ,  15.75,  18.  ])

# 创建格网
g = np.mgrid[1:4, 0:4]
print(g)

[[[1 1 1 1]
  [2 2 2 2]
  [3 3 3 3]]

 [[0 1 2 3]
  [0 1 2 3]
  [0 1 2 3]]]

# 随机生成
r = np.random.rand(3,3)
print(r)
# 带初值生成,注意括号((col, row, ..), type)
zero = np.zeros((3,3), dtype=np.float64)
print(zero)
one = np.ones((3,3))
print(one)

[[ 0.15798138  0.76426381  0.26221403]
 [ 0.98298431  0.94655075  0.00696479]
 [ 0.30875877  0.33322367  0.03711038]]
[[ 0.  0.  0.]
 [ 0.  0.  0.]
 [ 0.  0.  0.]]
[[ 1.  1.  1.]
 [ 1.  1.  1.]
 [ 1.  1.  1.]]

基本的描述元素

tmp = np.array([1,2,3])

print('数组为:')
print(tmp)
print("数据类型为:")
print(type(tmp))
print('数组大小:')
print(tmp.size)
print('数据类型:')
print(tmp.dtype)
print('数组维度:')
print(tmp.ndim)
print('数组形状:')
print(tmp.shape)
数组为:
[1 2 3]
数据类型为:
<class 'numpy.ndarray'>
数组大小:
3
数据类型:
int64
数组维度:
1
数组形状:
(3,)

序列化


test = np.random.rand(5, 5)
print(test)
np.save('../data/random-5.npy', test)
tmp = np.load('../data/random-5.npy')

索引和切片


In [63]:
# 切片 索引 和 赋值

info = np.array([['小明', '男', '10'],
               ['小红', '女', '11'],
               ['小刚', '男', '12']])
info
Out[63]:
array([['小明', '男', '10'],
       ['小红', '女', '11'],
       ['小刚', '男', '12']], 
      dtype='<U2')
In [83]:
#(最小值:最大值:采样间隔)  

# 按行来取值
小红 = info[1:2:1]  
print(小红)

# 按列取值
name = info[0:3, :1]
print(name)

age_index = [2]
print(info[::, age_index])
[['小红' '女' '11']]
[['小明']
 ['小红']
 ['小刚']]
[['10']
 ['11']
 ['12']]

各种矩阵运算


# 矩阵运算

mat = np.random.rand(3,3)
print(mat)

mat = mat + 2
mat = mat * -1
print(mat)

dot = np.dot(mat, mat)
print(dot)
# more: dot cross inner, outer  .T, .H  inv .I  mean std .max() .min() sum
[[ 0.19335883  0.6568079   0.1705884 ]
 [ 0.43722217  0.80471827  0.7774497 ]
 [ 0.77102649  0.41027065  0.61815674]]
[[-2.19335883 -2.6568079  -2.1705884 ]
 [-2.43722217 -2.80471827 -2.7774497 ]
 [-2.77102649 -2.41027065 -2.61815674]]
[[ 17.30081202  18.51063623  17.82297017]
 [ 19.87781102  21.0360812   20.35196874]
 [ 19.20720217  20.43268156  19.56390816]]

综合应用

以读csv文件为例,我们可以使用 csv模组或者直接用numpy来读,通过对比代码,我们会发现,numpy更加简洁。

使用CSV来读csv

# 读文件
import csv

index = [2,4,5]
# 读出前十个地区
with open('../data/cities.csv', 'rt') as file:
    reader = csv.DictReader(file)
    district = [row['district'] for row in reader]
    print(district[:10])
['北京市', '天安门', '东城区', '西城区', '崇文区', '宣武区', '朝阳区', '丰台区', '石景山区', '海淀区']

使用numpy

pos_index = [4, 5]
pos = np.genfromtxt('../data/cities.csv',delimiter=',', skip_header=True)[:, pos_index]
print(pos[:10])
[[ 116.4    39.9 ]
 [ 116.38   39.9 ]
 [ 116.42   39.93]
 [ 116.37   39.92]
 [ 116.43   39.88]
 [ 116.35   39.87]
 [ 116.43   39.92]
 [ 116.28   39.85]
 [ 116.22   39.9 ]
 [ 116.3    39.95]]

果然很简洁不是吗?顺便显示下这些点吧。
import matplotlib.pyplot as plt
%matplotlib inline
plt.scatter(pos[:, 0], pos[:,1])
plt.show()




本系列代码请见: github

人生苦短,我用python


本课程详细讲解了以下内容:    1.jsp环境搭建及入门、虚拟路径和虚拟主机、JSP执行流程    2.使用Eclipse快速开发JSP、编码问题、JSP页面元素以及request对象、使用request对象实现注册示例    3.请求方式的编码问题、response、请求转发和重定向、cookie、session执行机制、session共享问题     4.session与cookie问题及application、cookie补充说明及四种范围对象作用域     5.JDBC原理及使用Statement访问数据库、使用JDBC切换数据库以及PreparedStatement的使用、Statement与PreparedStatement的区别     6.JDBC调用存储过程和存储函数、JDBC处理大文本CLOB及二进制BLOB类型数据     7.JSP访问数据库、JavaBean(封装数据和封装业务逻辑)     8.MVC模式与Servlet执行流程、Servlet25与Servlet30的使用、ServletAPI详解与源码分析     9.MVC案例、三层架构详解、乱码问题以及三层代码流程解析、完善Service和Dao、完善View、优化用户体验、优化三层(加入接口和DBUtil)    1 0.Web调试及bug修复、分页SQL(Oracle、MySQL、SQLSERVER)     11.分页业务逻辑层和数据访问层Service、Dao、分页表示层Jsp、Servlet     12.文件上传及注意问题、控制文件上传类型和大小、下载、各浏览器下载乱码问题     13.EL表达式语法、点操作符和中括号操作符、EL运算、隐式对象、JSTL基础及set、out、remove     14.过滤器、过滤器通配符、过滤器链、监听器     15.session绑定解绑、钝化活化     16.以及Ajax的各种应用     17. Idea环境下的Java Web开发
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值