参考学习资料:

Python、NumPy和SciPy介绍:http://cs231n.github.io/python-numpy-tutorial

NumPy和SciPy快速入门:https://docs.scipy.org/doc/numpy-dev/user/quickstart.html

Python的数据分析: numpy和pandas入门:http://mp.weixin.qq.com/s/2GxvBC5WWRt8eT1JnVqx1w

1.ndarray的创建与数据类型

1.Numpy(Numerical Python)

Numpy:提供了一个在Python中做科学计算的基础库,重在数值计算,主要用于多维数组(矩阵)处理的库。用来存储和处理大型矩阵,比Python自身的嵌套列表结构要高效的多。本身是由C语言开发,是个很基础的扩展,Python其余的科学计算扩展大部分都是以此为基础。

  • 高性能科学计算和数据分析的基础包
  • ndarray,多维数组(矩阵),具有矢量运算能力,快速、节省空间
  • 矩阵运算,无需循环,可完成类似Matlab中的矢量运算
  • 线性代数、随机数生成
  • import numpy as np

2.ndarray 多维数组(N Dimension Array)

NumPy数组是一个多维的数组对象(矩阵),称为ndarray,具有矢量算术运算能力和复杂的广播能力,并具有执行速度快和节省空间的特点。

注意:ndarray的下标从0开始,且数组里的所有元素必须是相同类型

  • ndarray拥有的属性

    • ndim属性:维度个数
    • shape属性:维度大小
    • dtype属性:数据类型

ndarray的随机创建

通过随机抽样 (numpy.random) 生成随机数据。

  • 示例代码:
  1. # 导入numpy,别名np
  2. import numpy as np
  3.  
  4. # 生成指定维度大小(3行4列)的随机多维浮点型数据(二维),rand固定区间0.0 ~ 1.0
  5. arr = np.random.rand(3, 4)
  6. print(arr)
  7. print(type(arr))
  8.  
  9. # 生成指定维度大小(3行4列)的随机多维整型数据(二维),randint()可以指定区间(-1, 5)
  10. arr = np.random.randint(-1, 5, size = (3, 4)) # 'size='可省略
  11. print(arr)
  12. print(type(arr))
  13.  
  14. # 生成指定维度大小(3行4列)的随机多维浮点型数据(二维),uniform()可以指定区间(-1, 5)
  15. arr = np.random.uniform(-1, 5, size = (3, 4)) # 'size='可省略
  16. print(arr)
  17. print(type(arr))
  18.  
  19. print('维度个数: ', arr.ndim)
  20. print('维度大小: ', arr.shape)
  21. print('数据类型: ', arr.dtype)
  • 运行结果:
  1. [[ 0.09371338 0.06273976 0.22748452 0.49557778]
  2. [ 0.30840042 0.35659161 0.54995724 0.018144 ]
  3. [ 0.94551493 0.70916088 0.58877255 0.90435672]]
  4. <class 'numpy.ndarray'>
  5.  
  6. [[ 1 3 0 1]
  7. [ 1 4 4 3]
  8. [ 2 0 -1 -1]]
  9. <class 'numpy.ndarray'>
  10.  
  11. [[ 2.25275308 1.67484038 -0.03161878 -0.44635706]
  12. [ 1.35459097 1.66294159 2.47419548 -0.51144655]
  13. [ 1.43987571 4.71505054 4.33634358 2.48202309]]
  14. <class 'numpy.ndarray'>
  15.  
  16. 维度个数: 2
  17. 维度大小: (3, 4)
  18. 数据类型: float64

3.ndarray的序列创建

1. np.array(collection)

collection 为 序列型对象(list)、嵌套序列对象(list of list)。

  • 示例代码:
  1. # list序列转换为 ndarray
  2. lis = range(10)
  3. arr = np.array(lis)
  4.  
  5. print(arr) # ndarray数据
  6. print(arr.ndim) # 维度个数
  7. print(arr.shape) # 维度大小
  8.  
  9. # list of list嵌套序列转换为ndarray
  10. lis_lis = [range(10), range(10)]
  11. arr = np.array(lis_lis)
  12.  
  13. print(arr) # ndarray数据
  14. print(arr.ndim) # 维度个数
  15. print(arr.shape) # 维度大小
  • 运行结果:
  1. # list序列转换为 ndarray
  2. [0 1 2 3 4 5 6 7 8 9]
  3. 1
  4. (10,)
  5.  
  6. # list of list嵌套序列转换为 ndarray
  7. [[0 1 2 3 4 5 6 7 8 9]
  8. [0 1 2 3 4 5 6 7 8 9]]
  9. 2
  10. (2, 10)

2. np.zeros()

指定大小的全0数组。注意:第一个参数是元组,用来指定大小,如(3, 4)。

3. np.ones()

指定大小的全1数组。注意:第一个参数是元组,用来指定大小,如(3, 4)。

4. np.empty()

初始化数组,不是总是返回全0,有时返回的是未初始的随机值(内存里的随机值)。

  • 示例代码:
  1. # np.zeros
  2. zeros_arr = np.zeros((3, 4))
  3.  
  4. # np.ones
  5. ones_arr = np.ones((2, 3))
  6.  
  7. # np.empty
  8. empty_arr = np.empty((3, 3))
  9.  
  10. # np.empty 指定数据类型
  11. empty_int_arr = np.empty((3, 3), int)
  12.  
  13. print('------zeros_arr-------')
  14. print(zeros_arr)
  15.  
  16. print('\n------ones_arr-------')
  17. print(ones_arr)
  18.  
  19. print('\n------empty_arr-------')
  20. print(empty_arr)
  21.  
  22. print('\n------empty_int_arr-------')
  23. print(empty_int_arr)
  • 运行结果:
  1. ------zeros_arr-------
  2. [[ 0. 0. 0. 0.]
  3. [ 0. 0. 0. 0.]
  4. [ 0. 0. 0. 0.]]
  5.  
  6. ------ones_arr-------
  7. [[ 1. 1. 1.]
  8. [ 1. 1. 1.]]
  9.  
  10. ------empty_arr-------
  11. [[ 0. 0. 0.]
  12. [ 0. 0. 0.]
  13. [ 0. 0. 0.]]
  14.  
  15. ------empty_int_arr-------
  16. [[0 0 0]
  17. [0 0 0]
  18. [0 0 0]]

5. np.arange() 和 reshape()

arange() 类似 python 的 range() ,创建一个一维 ndarray 数组。

reshape() 将 重新调整数组的维数。

  • 示例代码:
  1. # np.arange()
  2. arr = np.arange(15) # 15个元素的 一维数组
  3. print(arr)
  4. print(arr.reshape(3, 5)) # 3x5个元素的 二维数组
  5. print(arr.reshape(1, 3, 5)) # 1x3x5个元素的 三维数组
  • 运行结果:
  1. [ 0 1 2 3 4 5 6 7 8 9 10 11 12 13 14]
  2.  
  3. [[ 0 1 2 3 4]
  4. [ 5 6 7 8 9]
  5. [10 11 12 13 14]]
  6.  
  7. [[[ 0 1 2 3 4]
  8. [ 5 6 7 8 9]
  9. [10 11 12 13 14]]]

6. np.arange() 和 random.shuffle()

random.shuffle() 将打乱数组序列(类似于洗牌)。

  • 示例代码:
  1. arr = np.arange(15)
  2. print(arr)
  3.  
  4. np.random.shuffle(arr)
  5. print(arr)
  6. print(arr.reshape(3,5))
  • 运行结果:
  1. [ 0 1 2 3 4 5 6 7 8 9 10 11 12 13 14]
  2.  
  3. [ 5 8 1 7 4 0 12 9 11 2 13 14 10 3 6]
  4.  
  5. [[ 5 8 1 7 4]
  6. [ 0 12 9 11 2]
  7. [13 14 10 3 6]]

4.ndarray的数据类型

1. dtype参数

指定数组的数据类型,类型名+位数,如float64, int32

2.astype方法

转换数组的数据类型

  • 示例代码:
  1. # 初始化3行4列数组,数据类型为float64
  2. zeros_float_arr = np.zeros((3, 4), dtype=np.float64)
  3. print(zeros_float_arr)
  4. print(zeros_float_arr.dtype)
  5.  
  6. # astype转换数据类型,将已有的数组的数据类型转换为int32
  7. zeros_int_arr = zeros_float_arr.astype(np.int32)
  8. print(zeros_int_arr)
  9. print(zeros_int_arr.dtype)
  • 运行结果:
  1. [[ 0. 0. 0. 0.]
  2. [ 0. 0. 0. 0.]
  3. [ 0. 0. 0. 0.]]
  4. float64
  5.  
  6. [[0 0 0 0]
  7. [0 0 0 0]
  8. [0 0 0 0]]
  9. int32

5.ndarray的矩阵运算

数组是编程中的概念,矩阵、矢量是数学概念。

在计算机编程中,矩阵可以用数组形式定义,矢量可以用结构定义!

1. 矢量运算:相同大小的数组间运算应用在元素上

  • 示例代码:
  1. # 矢量与矢量运算
  2. arr = np.array([[1, 2, 3],
  3. [4, 5, 6]])
  4.  
  5. print("元素相乘:")
  6. print(arr * arr)
  7.  
  8. print("矩阵相加:")
  9. print(arr + arr)
  • 运行结果:
  1. 元素相乘:
  2. [[ 1 4 9]
  3. [16 25 36]]
  4.  
  5. 矩阵相加:
  6. [[ 2 4 6]
  7. [ 8 10 12]]

2. 矢量和标量运算:"广播" - 将标量"广播"到各个元素

  • 示例代码:
  1. # 矢量与标量运算
  2. print(1. / arr)
  3. print(2. * arr)
  • 运行结果:
  1. [[ 1. 0.5 0.33333333]
  2. [ 0.25 0.2 0.16666667]]
  3.  
  4. [[ 2. 4. 6.]
  5. [ 8. 10. 12.]]

6.ndarray的索引与切片

1. 一维数组的索引与切片

与Python的列表索引功能相似

  • 示例代码:
  1. # 一维数组
  2. arr1 = np.arange(10)
  3. print(arr1)
  4. print(arr1[2:5])
  • 运行结果:
  1. [0 1 2 3 4 5 6 7 8 9]
  2. [2 3 4]

2. 多维数组的索引与切片:

  1. arr[r1:r2, c1:c2]
  2. arr[1,1] 等价 arr[1][1]
  3. [:] 代表某个维度的数据
  • 示例代码:
  1. # 多维数组
  2. arr2 = np.arange(12).reshape(3,4)
  3. print(arr2)
  4.  
  5. print(arr2[1])
  6.  
  7. print(arr2[0:2, 2:])
  8.  
  9. print(arr2[:, 1:3])
  • 运行结果:
  1. [[ 0 1 2 3]
  2. [ 4 5 6 7]
  3. [ 8 9 10 11]]
  4.  
  5. [4 5 6 7]
  6.  
  7. [[2 3]
  8. [6 7]]
  9.  
  10. [[ 1 2]
  11. [ 5 6]
  12. [ 9 10]]

3. 条件索引

布尔值多维数组:arr[condition],condition也可以是多个条件组合。

注意,多个条件组合要使用 & | 连接,而不是Python的 and or。

  • 示例代码:
  1. # 条件索引
  2.  
  3. # 找出 data_arr 中 2005年后的数据
  4. data_arr = np.random.rand(3,3)
  5. print(data_arr)
  6.  
  7. year_arr = np.array([[2000, 2001, 2000],
  8. [2005, 2002, 2009],
  9. [2001, 2003, 2010]])
  10.  
  11. is_year_after_2005 = year_arr >= 2005
  12. print(is_year_after_2005, is_year_after_2005.dtype)
  13.  
  14. filtered_arr = data_arr[is_year_after_2005]
  15. print(filtered_arr)
  16.  
  17. #filtered_arr = data_arr[year_arr >= 2005]
  18. #print(filtered_arr)
  19.  
  20. # 多个条件
  21. filtered_arr = data_arr[(year_arr <= 2005) & (year_arr % 2 == 0)]
  22. print(filtered_arr)
  • 运行结果:
  1. [[ 0.53514038 0.93893429 0.1087513 ]
  2. [ 0.32076215 0.39820313 0.89765765]
  3. [ 0.6572177 0.71284822 0.15108756]]
  4.  
  5. [[False False False]
  6. [ True False True]
  7. [False False True]] bool
  8.  
  9. [ 0.32076215 0.89765765 0.15108756]
  10.  
  11. #[ 0.32076215 0.89765765 0.15108756]
  12.  
  13. [ 0.53514038 0.1087513 0.39820313]

7.ndarray的维数转换

二维数组直接使用转换函数:transpose()

高维数组转换要指定维度编号参数 (0, 1, 2, …),注意参数是元组

  • 示例代码:
  1. arr = np.random.rand(2,3) # 2x3 数组
  2. print(arr)
  3. print(arr.transpose()) # 转换为 3x2 数组
  4.  
  5. arr3d = np.random.rand(2,3,4) # 2x3x4 数组,2对应0,3对应1,4对应3
  6. print(arr3d)
  7. print(arr3d.transpose((1,0,2))) # 根据维度编号,转为为 3x2x4 数组
  • 运行结果:
  1. # 二维数组转换
  2. # 转换前:
  3. [[ 0.50020075 0.88897914 0.18656499]
  4. [ 0.32765696 0.94564495 0.16549632]]
  5.  
  6. # 转换后:
  7. [[ 0.50020075 0.32765696]
  8. [ 0.88897914 0.94564495]
  9. [ 0.18656499 0.16549632]]
  10.  
  11. # 高维数组转换
  12. # 转换前:
  13. [[[ 0.91281153 0.61213743 0.16214062 0.73380458]
  14. [ 0.45539155 0.04232412 0.82857746 0.35097793]
  15. [ 0.70418988 0.78075814 0.70963972 0.63774692]]
  16.  
  17. [[ 0.17772347 0.64875514 0.48422954 0.86919646]
  18. [ 0.92771033 0.51518773 0.82679073 0.18469917]
  19. [ 0.37260457 0.49041953 0.96221477 0.16300198]]]
  20.  
  21. # 转换后:
  22. [[[ 0.91281153 0.61213743 0.16214062 0.73380458]
  23. [ 0.17772347 0.64875514 0.48422954 0.86919646]]
  24.  
  25. [[ 0.45539155 0.04232412 0.82857746 0.35097793]
  26. [ 0.92771033 0.51518773 0.82679073 0.18469917]]
  27.  
  28. [[ 0.70418988 0.78075814 0.70963972 0.63774692]
  29. [ 0.37260457 0.49041953 0.96221477 0.16300198]]]

8.ndarray的元素处理

元素计算函数

ceil(): 向上最接近的整数,参数是 number 或 array

floor():向下最接近的整数,参数是 number 或 array

rint(): 四舍五入,参数是 number 或 array

isnan(): 判断元素是否为 NaN(Not a Number),参数是 number 或 array

multiply(): 元素相乘,参数是 number 或 array

divide(): 元素相除,参数是 number 或 array

abs():元素的绝对值,参数是 number 或 array

where(condition, x, y):三元运算符,x if condition else y

  • 示例代码:
  1. # randn() 返回具有标准正态分布的序列。
  2. arr = np.random.randn(2,3)
  3.  
  4. print(arr)
  5.  
  6. print(np.ceil(arr))
  7.  
  8. print(np.floor(arr))
  9.  
  10. print(np.rint(arr))
  11.  
  12. print(np.isnan(arr))
  13.  
  14. print(np.multiply(arr, arr))
  15.  
  16. print(np.divide(arr, arr))
  17.  
  18. print(np.where(arr > 0, 1, -1))
  • 运行结果:
  1. # print(arr)
  2. [[-0.8350279 0.44716655 0.93326866]
  3. [ 0.22468383 -0.48611045 0.38554865]]
  4.  
  5. # print(np.ceil(arr))
  6. [[-0. 1. 1.]
  7. [ 1. -0. 1.]]
  8.  
  9. # print(np.floor(arr))
  10. [[-1. 0. 0.]
  11. [ 0. -1. 0.]]
  12.  
  13. # print(np.rint(arr))
  14. [[-1. 0. 1.]
  15. [ 0. -0. 0.]]
  16.  
  17. # print(np.isnan(arr))
  18. [[False False False]
  19. [False False False]]
  20.  
  21. # print(np.multiply(arr, arr))
  22. [[ 5.16284053e+00 1.77170104e+00 3.04027254e-02]
  23. [ 5.11465231e-03 3.46109263e+00 1.37512421e-02]]
  24.  
  25. # print(np.divide(arr, arr))
  26. [[ 1. 1. 1.]
  27. [ 1. 1. 1.]]
  28.  
  29. # print(np.where(arr > 0, 1, -1))
  30. [[-1 1 1]
  31. [ 1 -1 1]]

元素统计函数

1 .np.mean(), np.sum():所有元素的平均值,所有元素的和,参数是 number 或 array

2 .np.max(), np.min():所有元素的最大值,所有元素的最小值,参数是 number 或 array

3 .np.std(), np.var():所有元素的标准差,所有元素的方差,参数是 number 或 array

4 .np.argmax(), np.argmin():最大值的下标索引值,最小值的下标索引值,参数是 number 或 array

5 .np.cumsum(), np.cumprod():返回一个一维数组,每个元素都是之前所有元素的 累加和 和 累乘积,参数是 number 或 array

6 .多维数组默认统计全部维度,axis参数可以按指定轴心统计,值为0则按列统计,值为1则按行统计。

  • 示例代码:
  1. arr = np.arange(12).reshape(3,4)
  2. print(arr)
  3.  
  4. print(np.cumsum(arr)) # 返回一个一维数组,每个元素都是之前所有元素的 累加和
  5.  
  6. print(np.sum(arr)) # 所有元素的和
  7.  
  8. print(np.sum(arr, axis=0)) # 数组的按列统计和
  9.  
  10. print(np.sum(arr, axis=1)) # 数组的按行统计和
  • 运行结果:
  1. # print(arr)
  2. [[ 0 1 2 3]
  3. [ 4 5 6 7]
  4. [ 8 9 10 11]]
  5.  
  6. # print(np.cumsum(arr))
  7. [ 0 1 3 6 10 15 21 28 36 45 55 66]
  8.  
  9. # print(np.sum(arr)) # 所有元素的和
  10. 66
  11.  
  12. # print(np.sum(arr, axis=0)) # 0表示对数组的每一列的统计和
  13. [12 15 18 21]
  14.  
  15. # print(np.sum(arr, axis=1)) # 1表示数组的每一行的统计和
  16. [ 6 22 38]

元素判断函数

1 .np.any(): 至少有一个元素满足指定条件,返回True

2 .np.all(): 所有的元素满足指定条件,返回True

  • 示例代码:
  1. arr = np.random.randn(2,3)
  2. print(arr)
  3.  
  4. print(np.any(arr > 0))
  5. print(np.all(arr > 0))
  • 运行结果:
  1. [[ 0.05075769 -1.31919688 -1.80636984]
  2. [-1.29317016 -1.3336612 -0.19316432]]
  3.  
  4. True
  5. False

元素去重排序函数

np.unique():找到唯一值并返回排序结果,类似于Python的set集合

  • 示例代码:
  1. arr = np.array([[1, 2, 1], [2, 3, 4]])
  2. print(arr)
  3.  
  4. print(np.unique(arr))
  • 运行结果:
  1. [[1 2 1]
  2. [2 3 4]]
  3.  
  4. [1 2 3 4]

9.2016年美国总统大选民意调查数据统计

项目地址:https://www.kaggle.com/fivethirtyeight/2016-election-polls

该数据集包含了2015年11月至2016年11月期间对于2016美国大选的选票数据,共27列数据

  • 示例代码1 :
  1. # loadtxt
  2. import numpy as np
  3.  
  4. # csv 名逗号分隔值文件
  5. filename = './presidential_polls.csv'
  6.  
  7. # 通过loadtxt()读取本地csv文件
  8. data_array = np.loadtxt(filename, # 文件名
  9. delimiter=',', # 分隔符
  10. dtype=str, # 数据类型,数据是Unicode字符串
  11. usecols=(0,2,3)) # 指定读取的列号
  12.  
  13. # 打印ndarray数据,保留第一行
  14. print(data_array, data_array.shape)
  • 运行结果:
  1. [["b'cycle'" "b'type'" "b'matchup'"]
  2. ["b'2016'" 'b\'"polls-plus"\'' 'b\'"Clinton vs. Trump vs. Johnson"\'']
  3. ["b'2016'" 'b\'"polls-plus"\'' 'b\'"Clinton vs. Trump vs. Johnson"\'']
  4. ...,
  5. ["b'2016'" 'b\'"polls-only"\'' 'b\'"Clinton vs. Trump vs. Johnson"\'']
  6. ["b'2016'" 'b\'"polls-only"\'' 'b\'"Clinton vs. Trump vs. Johnson"\'']
  7. ["b'2016'" 'b\'"polls-only"\'' 'b\'"Clinton vs. Trump vs. Johnson"\'']] (10237, 3)
  • 示例代码2:
  1. import numpy as np
  2. # 读取列名,即第一行数据
  3. with open(filename, 'r') as f:
  4. col_names_str = f.readline()[:-1] # [:-1]表示不读取末尾的换行符'\n'
  5.  
  6. # 将字符串拆分,并组成列表
  7. col_name_lst = col_names_str.split(',')
  8.  
  9. # 使用的列名:结束时间,克林顿原始票数,川普原始票数,克林顿调整后票数,川普调整后票数
  10. use_col_name_lst = ['enddate', 'rawpoll_clinton', 'rawpoll_trump','adjpoll_clinton', 'adjpoll_trump']
  11.  
  12. # 获取相应列名的索引号
  13. use_col_index_lst = [col_name_lst.index(use_col_name) for use_col_name in use_col_name_lst]
  14.  
  15. # 通过genfromtxt()读取本地csv文件,
  16. data_array = np.genfromtxt(filename, # 文件名
  17. delimiter=',', # 分隔符
  18. #skiprows=1, # 跳过第一行,即跳过列名
  19. dtype=str, # 数据类型,数据不再是Unicode字符串
  20. usecols=use_col_index_lst)# 指定读取的列索引号
  21.  
  22. # genfromtxt() 不能通过 skiprows 跳过第一行的
  23. # ['enddate' 'rawpoll_clinton' 'rawpoll_trump' 'adjpoll_clinton' 'adjpoll_trump']
  24.  
  25. # 去掉第一行
  26. data_array = data_array[1:]
  27.  
  28. # 打印ndarray数据
  29. print(data_array[1:], data_array.shape)
  • 运行结果:
  1. [[' '43.29659' '44.72984']
  2. [' '46.29779' '40.72604']
  3. [' '46.35931' '45.30585']
  4. ...,
  5. ['9/22/2016' '46.54' '40.04' '45.9713' '39.97518']
  6. [' '45.2939' '46.66175']
  7. ['8/18/2016' '32.54' '43.61' '31.62721' '44.65947']] (10236, 5)


科学计算工具Numpy的更多相关文章

  1. 科学计算工具Numpy简介

    Numpy(Numerical Python) Numpy:提供了一个在Python中做科学计算的基础库,重在数值计算,主要用于多维数组(矩阵)处理的库.用来存储和处理大型矩阵,比Python自身的嵌 ...

  2. 科学计算工具-Numpy初探

    Numpy基础数据结构 Numpy数组是一个多维数组,称为ndarray.其由两部分组成: 实际的数据 描述这些数据的原数据 导入该库: import numpy as np 多维数组ndarray ...

  3. 动态可视化 数据可视化之魅D3,Processing,pandas数据分析,科学计算包Numpy,可视化包Matplotlib,Matlab语言可视化的工作,Matlab没有指针和引用是个大问题

    动态可视化 数据可视化之魅D3,Processing,pandas数据分析,科学计算包Numpy,可视化包Matplotlib,Matlab语言可视化的工作,Matlab没有指针和引用是个大问题 D3 ...

  4. python科学计算之numpy

    1.np.logspace(start,stop,num): 函数表示的意思是;在(start,stop)间生成等比数列num个 eg: import numpy as np print np.log ...

  5. Python科学计算库Numpy

    Python科学计算库Numpy NumPy(Numerical Python) 是 Python 语言的一个扩展程序库,支持大量的维度数组与矩阵运算,此外也针对数组运算提供大量的数学函数库. 1.简 ...

  6. 科学计算库Numpy基础&提升(理解+重要函数讲解)

    Intro 对于同样的数值计算任务,使用numpy比直接编写python代码实现 优点: 代码更简洁: numpy直接以数组.矩阵为粒度计算并且支持大量的数学函数,而python需要用for循环从底层 ...

  7. 数据分析与科学计算可视化-----用于科学计算的numpy库与可视化工具matplotlib

    一.numpy库与matplotlib库的基本介绍 1.安装 (1)通过pip安装: >> pip install matplotlib 安装完成 安装matplotlib的方式和nump ...

  8. python科学计算库numpy和绘图库PIL的结合,素描图片(原创)

    # 导入绘图库 from PIL import Image #导入科学计算库 import numpy as np #封装一个图像处理工具类 class TestNumpy(object): def ...

  9. python科学计算模块NumPy

    NumPy是Numerical Python的简称,是高性能科学计算和数据分析的基础包.其实NumPy 本身并并没有提供太多的高级的数据分析功能, 但是理解NumPy数组以及面向数组的计算将有利于你更 ...

随机推荐

  1. Java I/O最简单的几个类

    今天把I/O中最简单的几个类整理了一下,之所以整理最简单的,是因为这样会让我更加快速方便的理顺这里面的东西,以前每一次用的时候都要先百度一下,觉得很烦. 首先需要先看一下Read,Write和Stre ...

  2. 恶补web之一:html学习(1)

    发现以前欠下的web知识太多鸟,只有重头开始好好学吧,恶补第一站就是html知识啦! html指的是超文本标记语言,它不是编程语言,而是一种标记语言;标记语言是一套标记标签(markup tag),h ...

  3. Idea(一) 安装与破解

    现在idea横行的时代,没用过idea都不好意思了,于是乎,我也下载感受下. 下载安装包和破解地址: 链接: https://pan.baidu.com/s/16OeiDw942JaPXKtc9Oz1 ...

  4. 鹅厂优文|打通小程序音视频和webRTC

    欢迎大家前往腾讯云+社区,获取更多腾讯海量技术实践干货哦~ 作者:腾讯视频云终端技术总监常青, 2008 年毕业加入腾讯,一直从事客户端研发相关工作,先后参与过 PC QQ.手机QQ.QQ物联 等产品 ...

  5. 修改was数据源

    本机的RAD运行的工程可以通过修改jpa中的persistence中的jni修改数据源: 对于通过was控制台部署的ear需要在was控制台:资源--jdbc 修改数据源

  6. SQL语言逻辑执行顺序

    SQL语言逻辑执行顺序 2012-12-18 16:18:13 分类: 数据库开发技术 查询的逻辑执行顺序 FROM < left_table> ON < join_conditio ...

  7. Ribbon整合Eureka组件,以实现负载均衡

    1整体框架的说明 在本案例的框架里,我们将配置一个Eureka服务器,搭建三个提供相同服务的Eureka服务提供者,同时在Eureka服务调用者里引入Ribbon组件,这样,当有多个url向服务调用者 ...

  8. 学习了解 Exchanger - 实现生产者消费者模型

    例子很简单 Exchanger可以理解为消息队列或者说是一个通信管道,从一边拿到消息,另外一边进行消费. 不过这个是同步实现的,消费者在exchange之前,生产者一直处于等待状态,而不是一直生产. ...

  9. Linux中mongodb定时远程备份

    下载mongodb https://www.cnblogs.com/tartis/p/5291580.html mongodb定时备份文档 虚拟机报错要改BIOS 虚拟技术开启 进入root账户  s ...

  10. Hype-v 共享文件办法

    Hype-v在Windows下跑Windows系统,其效率要远好于VMWare,唯一蛋疼的就是剪贴板不能复制文件.共享文件的方案就剩下以下几种: 远程访问 虚拟磁盘 挂载镜像 挂载镜像把每个文件都制作 ...