NumPy

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

  • 高性能科学计算和数据分析的基础包

  • ndarray,多维数组(矩阵),具有矢量运算能力,快速、节省空间

  • 矩阵运算,无需循环,可完成类似Matlab中的矢量运算

  • 线性代数、随机数生成

使用以下语句导入 Numpy 库:

import numpy as np

NumPy 数组

创建数组

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

>>> b = np.array([(1.5,2,3), (4,5,6)], dtype = float)

>>> c = np.array([[(1.5,2,3), (4,5,6)], [(3,2,1), (4,5,6)]], dtype = float)

初始化占位符

>>> np.zeros((3,4))# 创建值为0数组

>>> np.ones((2,3,4),dtype=np.int16)# 创建值为1数组

>>> d = np.arange(10,25,5)# 创建均匀间隔的数组(步进值)

>>> np.linspace(0,2,9)# 创建均匀间隔的数组(样本数)

>>> e = np.full((2,2),7)# 创建常数数组

>>> f = np.eye(2)# 创建2x2单位矩阵

>>> np.random.random((2,2))# 创建随机值的数组

>>> np.empty((3,2))#创建空数组

输入/输出

保存与载入磁盘上的文件

>>> np.save('my_array', a)

>>> np.savez('array.npz', a, b)

>>> np.load('my_array.npy')

保存与载入文本文件

>>> np.loadtxt("myfile.txt")

>>> np.genfromtxt("my_file.csv", delimiter=',')

>>> np.savetxt("myarray.txt", a, delimiter=" ")

数据类型

>>> np.int64# 带符号的64位整数

>>> np.float32# 标准双精度浮点数

>>> np.complex# 显示为128位浮点数的复数 

>>> np.bool#  布尔值:True值和False值 

>>> np.object#Python对象 

>>> np.string_# 固定长度字符串

>>> np.unicode_# 固定长度Unicode

数组信息

>>> a.shape# 数组形状 几行几列 

>>> len(a) #数组长度

>>> b.ndim #几维数组

>>> e.size# 数组有多少元素

>>> b.dtype# 数据类型 

>>> b.dtype.name# 数据类型的名字

>>> b.astype(int) #数据类型转换

调用帮助

>>> np.info(np.ndarray.dtype)

数组计算

算数运算

减法 减法 加法 加法 除法 除法 乘法 乘法 幂 平方根 正弦 余弦 自然对数 点积
>>> g = a - b array([[-0.5, 0. , 0. ], [-3. , -3. , -3. ]])

>>> np.subtract(a,b)

>>> b + a array([[ 2.5, 4. , 6. ], [ 5. , 7. , 9. ]])

>>> np.add(b,a)

>>> a / b array([[ 0.66666667, 1. , 1. ], [ 0.25 , 0.4 , 0.5 ]])

>>> np.divide(a,b)

>>> a * b array([[ 1.5, 4. , 9. ], [ 4. , 10. , 18. ]])

>>> np.multiply(a,b)

>>> np.exp(b)

>>> np.sqrt(b)

>>> np.sin(a)

>>> np.cos(b)

>>> np.log(a)

>>> e.dot(f)

array([[ 7., 7.], [ 7., 7.]])

比较

>>> a == b array([[False, True, True], [False, False, False]], dtype=bool)# 对比值

>>> a < 2 array([True, False, False], dtype=bool)# 对比值 

>>> np.array_equal(a, b)  # 对比数组

聚合函数

>>> a.sum()# 数组汇总

>>> a.min()#  数组最小值

>>> b.max(axis=0)#数组最大值

>>> b.cumsum(axis=1)# 按行 数组元素的累加值

>>> a.mean()# 平均数

>>> b.median()# 中位数 

>>> a.corrcoef()# 相关系数

>>> np.std(b)#  标准差

数组复制

>>> h = a.view()# 使用同一数据创建数组视图

>>> np.copy(a)# 创建数组的副本

>>> h = a.copy() #  创建数组的深度拷贝

数组排序

>>> a.sort()# 数组排序

>>> c.sort(axis=0) #  以轴为依据对数组排序

子集、切片、 索引

a:b:

子集

>>> a[2]# 选择索引2对应的值

3

>>>b[1,2]#选择行1列2对应的值(等同于b[1][2]

6.0

切片

>>> a[0:2] #  选择索引为0与1对应的值 

array([1, 2])

>>> b[0:2,1]# 选择第1列中第0行、第1行的值

array([ 2., 5.])

>>> b[:1]#  选择第0行的所有值(等同于b[0:1,:1]

array([[1.5, 2., 3.]])

>>> c[1,...]#  等同于 [1,:,:]

array([[[ 3., 2., 1.], [ 4., 5., 6.]]])

>>> a[ : :-1]#  反转数组a

array([3, 2, 1])

条件索引

>>> a[a<2]#  选择数组a中所有小于2的值 

array([1])

花式索引

>>> b[[1, 0, 1, 0],[0, 1, 2, 0]]# 选择(1,0),(0,1),(1,2) 和(0,0)所对应的值

array([ 4. , 2. , 6. , 1.5])

>>> b[[1, 0, 1, 0]][:,[0,1,2,0]]# 选择矩阵的行列子集 

array([[ 4. ,5. , 6. , 4. ], [ 1.5, 2. , 3. , 1.5], [ 4. , 5. , 6. , 4. ], [ 1.5, 2. , 3. , 1.5]])

数组操作

转置数组

>>> i = np.transpose(b)# 转置数组

>>> i.T# 转置数组

改变数组形状

>>> b.ravel()# 拉平数组

>>> g.reshape(3,-2)# 改变数组形状,但不改变数据

添加或删除值

>>> h.resize((2,6))# 返回形状为(2,6)的新数组

>>> np.append(h,g)# 追加数据

>>> np.insert(a, 1, 5)# 插入数据

>>> np.delete(a,[1])# 删除数据

合并数组

>>> np.concatenate((a,d),axis=0)# 拼接数组

array([ 1, 2, 3, 10, 15, 20])

>>> np.vstack((a,b))# 纵向以行的维度堆叠数组 

array([[ 1. , 2. , 3. ], [ 1.5, 2. , 3. ], [ 4. , 5. , 6. ]])

>>> np.r_[e,f]# 纵向以行的维度堆叠数组

>>> np.hstack((e,f))# 横向以列的维度堆叠数组 

array([[ 7., 7., 1., 0.], [ 7., 7., 0., 1.]])

>>> np.column_stack((a,d))# 以列的维度创建堆叠数组

array([[ 1, 10], [ 2, 15], [ 3, 20]])

 >>> np.c_[a,d] # 以列的维度创建堆叠数组

分割数组

>>> np.hsplit(a,3)#  纵向分割数组为3等份
[array([1]),array([2]),array([3])] >>> np.vsplit(c,2) # 横向分割数组为2等份 [array([[[ 1.5, 2. , 1. ], [ 4. , 5. , 6. ]]]), array([[[ 3., 2., 3.], [ 4., 5., 6.]]])]

ndarray的随机创建

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

示例代码:

# 导入numpy,别名np
import numpy as np # 生成指定维度大小(3行4列)的随机多维浮点型数据(二维),rand固定区间0.0 ~ 1.0
arr = np.random.rand(3, 4)
print(arr)
print(type(arr)) # 生成指定维度大小(3行4列)的随机多维整型数据(二维),randint()可以指定区间(-1, 5)
arr = np.random.randint(-1, 5, size = (3, 4)) # 'size='可省略
print(arr)
print(type(arr)) # 生成指定维度大小(3行4列)的随机多维浮点型数据(二维),uniform()可以指定区间(-1, 5)
arr = np.random.uniform(-1, 5, size = (3, 4)) # 'size='可省略
print(arr)
print(type(arr)) print('维度个数: ', arr.ndim)
print('维度大小: ', arr.shape)
print('数据类型: ', arr.dtype)

运行结果:

[[ 0.09371338  0.06273976  0.22748452  0.49557778]
[ 0.30840042 0.35659161 0.54995724 0.018144 ]
[ 0.94551493 0.70916088 0.58877255 0.90435672]]
<class 'numpy.ndarray'> [[ 1 3 0 1]
[ 1 4 4 3]
[ 2 0 -1 -1]]
<class 'numpy.ndarray'> [[ 2.25275308 1.67484038 -0.03161878 -0.44635706]
[ 1.35459097 1.66294159 2.47419548 -0.51144655]
[ 1.43987571 4.71505054 4.33634358 2.48202309]]
<class 'numpy.ndarray'> 维度个数: 2
维度大小: (3, 4)
数据类型: float64

ndarray的序列创建

np.array(collection)

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

示例代码:

# list序列转换为 ndarray
lis = range(10)
arr = np.array(lis) print(arr) # ndarray数据
print(arr.ndim) # 维度个数
print(arr.shape) # 维度大小 # list of list嵌套序列转换为ndarray
lis_lis = [range(10), range(10)]
arr = np.array(lis_lis) print(arr) # ndarray数据
print(arr.ndim) # 维度个数
print(arr.shape) # 维度大小

运行结果:

# list序列转换为 ndarray
[0 1 2 3 4 5 6 7 8 9]
1
(10,) # list of list嵌套序列转换为 ndarray
[[0 1 2 3 4 5 6 7 8 9]
[0 1 2 3 4 5 6 7 8 9]]
2
(2, 10)

np.zeros()

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

np.ones()

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

np.empty()

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

示例代码:

# np.zeros
zeros_arr = np.zeros((3, 4)) # np.ones
ones_arr = np.ones((2, 3)) # np.empty
empty_arr = np.empty((3, 3)) # np.empty 指定数据类型
empty_int_arr = np.empty((3, 3), int) print('------zeros_arr-------')
print(zeros_arr) print('\n------ones_arr-------')
print(ones_arr) print('\n------empty_arr-------')
print(empty_arr) print('\n------empty_int_arr-------')
print(empty_int_arr)

运行结果:

------zeros_arr-------
[[ 0. 0. 0. 0.]
[ 0. 0. 0. 0.]
[ 0. 0. 0. 0.]] ------ones_arr-------
[[ 1. 1. 1.]
[ 1. 1. 1.]] ------empty_arr-------
[[ 0. 0. 0.]
[ 0. 0. 0.]
[ 0. 0. 0.]] ------empty_int_arr-------
[[0 0 0]
[0 0 0]
[0 0 0]]

5. np.arange() 和 reshape()

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

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

示例代码:

# np.arange()
arr = np.arange(15) # 15个元素的 一维数组
print(arr)
print(arr.reshape(3, 5)) # 3x5个元素的 二维数组
print(arr.reshape(1, 3, 5)) # 1x3x5个元素的 三维数组

运行结果:

[ 0  1  2  3  4  5  6  7  8  9 10 11 12 13 14]

[[ 0  1  2  3  4]
[ 5 6 7 8 9]
[10 11 12 13 14]] [[[ 0 1 2 3 4]
[ 5 6 7 8 9]
[10 11 12 13 14]]]

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

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

示例代码:

arr = np.arange(15)
print(arr) np.random.shuffle(arr)
print(arr)
print(arr.reshape(3,5))

运行结果:

[ 0  1  2  3  4  5  6  7  8  9 10 11 12 13 14]

[ 5  8  1  7  4  0 12  9 11  2 13 14 10  3  6]

[[ 5  8  1  7  4]
[ 0 12 9 11 2]
[13 14 10 3 6]]

ndarray的数据类型

1. dtype参数

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

2. astype方法

转换数组的数据类型

示例代码(1、2):

# 初始化3行4列数组,数据类型为float64
zeros_float_arr = np.zeros((3, 4), dtype=np.float64)
print(zeros_float_arr)
print(zeros_float_arr.dtype) # astype转换数据类型,将已有的数组的数据类型转换为int32
zeros_int_arr = zeros_float_arr.astype(np.int32)
print(zeros_int_arr)
print(zeros_int_arr.dtype)

运行结果:

[[ 0.  0.  0.  0.]
[ 0. 0. 0. 0.]
[ 0. 0. 0. 0.]]
float64 [[0 0 0 0]
[0 0 0 0]
[0 0 0 0]]
int32

ndarray的矩阵运算

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

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

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

# 矢量与矢量运算
arr = np.array([[1, 2, 3],
[4, 5, 6]]) print("元素相乘:")
print(arr * arr) print("矩阵相加:")
print(arr + arr)

运行结果:

元素相乘:
[[ 1 4 9]
[16 25 36]] 矩阵相加:
[[ 2 4 6]
[ 8 10 12]]

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

# 矢量与标量运算
print(1. / arr)
print(2. * arr)

运行结果:

[[ 1.          0.5         0.33333333]
[ 0.25 0.2 0.16666667]] [[ 2. 4. 6.]
[ 8. 10. 12.]]

ndarray的索引与切片

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

与Python的列表索引功能相似

# 一维数组
arr1 = np.arange(10)
print(arr1)
print(arr1[2:5])

运行结果:

[0 1 2 3 4 5 6 7 8 9]
[2 3 4]

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

arr[r1:r2, c1:c2]

arr[1,1] 等价 arr[1][1]

[:] 代表某个维度的数据

# 多维数组
arr2 = np.arange(12).reshape(3,4)
print(arr2) print(arr2[1]) print(arr2[0:2, 2:]) print(arr2[:, 1:3])

运行结果:

[[ 0  1  2  3]
[ 4 5 6 7]
[ 8 9 10 11]] [4 5 6 7] [[2 3]
[6 7]] [[ 1 2]
[ 5 6]
[ 9 10]]

3. 条件索引

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

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

# 条件索引

# 找出 data_arr 中 2005年后的数据
data_arr = np.random.rand(3,3)
print(data_arr) year_arr = np.array([[2000, 2001, 2000],
[2005, 2002, 2009],
[2001, 2003, 2010]]) is_year_after_2005 = year_arr >= 2005
print(is_year_after_2005, is_year_after_2005.dtype) filtered_arr = data_arr[is_year_after_2005]
print(filtered_arr) #filtered_arr = data_arr[year_arr >= 2005]
#print(filtered_arr) # 多个条件
filtered_arr = data_arr[(year_arr <= 2005) & (year_arr % 2 == 0)]
print(filtered_arr)

运行结果:

[[ 0.53514038  0.93893429  0.1087513 ]
[ 0.32076215 0.39820313 0.89765765]
[ 0.6572177 0.71284822 0.15108756]] [[False False False]
[ True False True]
[False False True]] bool [ 0.32076215 0.89765765 0.15108756] [ 0.32076215 0.89765765 0.15108756] [ 0.53514038 0.1087513 0.39820313]

ndarray的维数转换

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

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

arr = np.random.rand(2,3)    # 2x3 数组
print(arr)
print(arr.transpose()) # 转换为 3x2 数组 arr3d = np.random.rand(2,3,4) # 2x3x4 数组,2对应0,3对应1,4对应3
print(arr3d)
print(arr3d.transpose((1,0,2))) # 根据维度编号,转为为 3x2x4 数组

运行结果:

# 二维数组转换
# 转换前:
[[ 0.50020075 0.88897914 0.18656499]
[ 0.32765696 0.94564495 0.16549632]] # 转换后:
[[ 0.50020075 0.32765696]
[ 0.88897914 0.94564495]
[ 0.18656499 0.16549632]] # 高维数组转换
# 转换前:
[[[ 0.91281153 0.61213743 0.16214062 0.73380458]
[ 0.45539155 0.04232412 0.82857746 0.35097793]
[ 0.70418988 0.78075814 0.70963972 0.63774692]] [[ 0.17772347 0.64875514 0.48422954 0.86919646]
[ 0.92771033 0.51518773 0.82679073 0.18469917]
[ 0.37260457 0.49041953 0.96221477 0.16300198]]] # 转换后:
[[[ 0.91281153 0.61213743 0.16214062 0.73380458]
[ 0.17772347 0.64875514 0.48422954 0.86919646]] [[ 0.45539155 0.04232412 0.82857746 0.35097793]
[ 0.92771033 0.51518773 0.82679073 0.18469917]] [[ 0.70418988 0.78075814 0.70963972 0.63774692]
[ 0.37260457 0.49041953 0.96221477 0.16300198]]]

元素计算函数

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

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

  3. rint(): 四舍五入,参数是 number 或 array
  4. isnan(): 判断元素是否为 NaN(Not a Number),参数是 number 或 array
  5. multiply(): 元素相乘,参数是 number 或 array
  6. divide(): 元素相除,参数是 number 或 array
  7. abs():元素的绝对值,参数是 number 或 array
  8. where(condition, x, y): 三元运算符,x if condition else y
# randn() 返回具有标准正态分布的序列。
arr = np.random.randn(2,3) print(arr) print(np.ceil(arr)) print(np.floor(arr)) print(np.rint(arr)) print(np.isnan(arr)) print(np.multiply(arr, arr)) print(np.divide(arr, arr)) print(np.where(arr > 0, 1, -1))

运行结果:

# print(arr)
[[-0.75803752 0.0314314 1.15323032]
[ 1.17567832 0.43641395 0.26288021]] # print(np.ceil(arr))
[[-0. 1. 2.]
[ 2. 1. 1.]] # print(np.floor(arr))
[[-1. 0. 1.]
[ 1. 0. 0.]] # print(np.rint(arr))
[[-1. 0. 1.]
[ 1. 0. 0.]] # print(np.isnan(arr))
[[False False False]
[False False False]] # print(np.multiply(arr, arr))
[[ 5.16284053e+00 1.77170104e+00 3.04027254e-02]
[ 5.11465231e-03 3.46109263e+00 1.37512421e-02]] # print(np.divide(arr, arr))
[[ 1. 1. 1.]
[ 1. 1. 1.]] # print(np.where(arr > 0, 1, -1))
[[ 1 1 -1]
[-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则按行统计。
arr = np.arange(12).reshape(3,4)
print(arr) print(np.cumsum(arr)) # 返回一个一维数组,每个元素都是之前所有元素的 累加和 print(np.sum(arr)) # 所有元素的和 print(np.sum(arr, axis=0)) # 数组的按列统计和 print(np.sum(arr, axis=1)) # 数组的按行统计和

运行结果:

# print(arr)
[[ 0 1 2 3]
[ 4 5 6 7]
[ 8 9 10 11]] # print(np.cumsum(arr))
[ 0 1 3 6 10 15 21 28 36 45 55 66] # print(np.sum(arr)) # 所有元素的和
66 # print(np.sum(arr, axis=0)) # 0表示对数组的每一列的统计和
[12 15 18 21] # print(np.sum(arr, axis=1)) # 1表示数组的每一行的统计和
[ 6 22 38]

元素判断函数

  1. np.any(): 至少有一个元素满足指定条件,返回True
  2. np.all(): 所有的元素满足指定条件,返回True
arr = np.random.randn(2,3)
print(arr) print(np.any(arr > 0))
print(np.all(arr > 0))

运行结果:

[[ 0.05075769 -1.31919688 -1.80636984]
[-1.29317016 -1.3336612 -0.19316432]] True
False

元素去重排序函数

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

arr = np.array([[1, 2, 1], [2, 3, 4]])
print(arr) print(np.unique(arr))

运行结果:

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

最后补充一个库Scipy

Scipy :基于Numpy提供了一个在Python中做科学计算的工具集,专为科学和工程设计的Python工具包。主要应用于统计、优化、整合、线性代数模块、傅里叶变换、信号和图像处理、常微分方程求解、稀疏矩阵等,在数学系或者工程系相对用的多一些,和数据处理的关系不大, 我们知道即可,这里不做讲解。

  • 在NumPy库的基础上增加了众多的数学、科学及工程常用的库函数

  • 线性代数、常微分方程求解、信号处理、图像处理

  • 一般的数据处理numpy已经够用

  • import scipy as sp

Python 数据科学-Numpy的更多相关文章

  1. Python数据科学手册

    Python数据科学手册(高清版)PDF 百度网盘 链接:https://pan.baidu.com/s/1KurSdjNWiwMac3o3iLrzBg 提取码:qogy 复制这段内容后打开百度网盘手 ...

  2. python书籍推荐:Python数据科学手册

    所属网站分类: 资源下载 > python电子书 作者:today 链接:http://www.pythonheidong.com/blog/article/448/ 来源:python黑洞网 ...

  3. Python数据科学安装Numby,pandas,scipy,matpotlib等(IPython安装pandas)

    Python数据科学安装Numby,pandas,scipy,matpotlib等(IPython安装pandas) 如果还没有本地安装Python.IPython.notebook等请移步 上篇Py ...

  4. 100天搞定机器学习|day45-53 推荐一本豆瓣评分9.3的书:《Python数据科学手册》

    <Python数据科学手册>共五章,每章介绍一到两个Python数据科学中的重点工具包.首先从IPython和Jupyter开始,它们提供了数据科学家需要的计算环境:第2章讲解能提供nda ...

  5. 《Python数据科学手册》

    <Python数据科学手册>[美]Jake VanderPlas著 陶俊杰译 Absorb what is useful, discard what is not, and  add wh ...

  6. 干货!小白入门Python数据科学全教程

    前言 本文讲解了从零开始学习Python数据科学的全过程,涵盖各种工具和方法 你将会学习到如何使用python做基本的数据分析 你还可以了解机器学习算法的原理和使用 说明 先说一段题外话.我是一名数据 ...

  7. Python数据科学手册-前言

    读Python数据科学手册 笔记 系列 数据科学 data science https://img2022.cnblogs.com/blog/2827305/202205/2827305-202205 ...

  8. Matplotlib 使用 - 《Python 数据科学手册》学习笔记

    一.引入 import matplotlib as mpl import matplotlib.pyplot as plt 二.配置 1.画图接口 Matplotlib 有两种画图接口: (1)一个是 ...

  9. 《Python数据科学手册》第五章机器学习的笔记

    目录 <Python数据科学手册>第五章机器学习的笔记 0. 写在前面 1. 判定系数 2. 朴素贝叶斯 3. 自举重采样方法 4. 白化 5. 机器学习章节总结 <Python数据 ...

随机推荐

  1. 【题解】【P3383 【模板】线性筛素数】

    看完这篇博客你就懂了 原题链接 代码: #include<bits/stdc++.h> using namespace std; bool isPrime(int num) { if(nu ...

  2. 模板配置教程:Phpcms v9怎么更换模板

    先分享下大概的步骤: 1.上传模版文件到服务器: 2.在站点管理 里边[模板风格配置]选择新模板: 3.设置不同模型对应模板: 4.修改现有的栏目,匹配新模板: 5.更新栏目缓存.系统缓存,更新HTM ...

  3. java练习---7

    //程序员:罗元昊 2017.10.7 import java.util.Scanner; public class L { public static void main(String[] args ...

  4. Python基础总结之第六天开始【认识List:列表】【认识Tuple:元组】【还有他们基本的操作】(新手可相互督促)

    早,在北京的周六,热到不行~~~ 今天更新笔记列表(List).元组(Tuple)以及它们的操作方法 在列表中会经常用到List列表,前面我们认识到的有字符串,字符串数据是不能修改当前字符串里面的任意 ...

  5. java读写文件小心缓存数组

    一般我们读写文件的时候都是这么写的,看着没问题哈.   public static void main(String[] args) throws Exception {   FileInputStr ...

  6. HTTP_5_通信数据转发程序:代理、网关、隧道

    HTTP通信时,除客户端和服务器之外,还有一些用于通信数据转发的应用程序,例如代理,网关,隧道.配合服务器工作. 代理 转发功能,客户端与服务器之间可有多个代理, 缓存代理:减少服务器压力,透明代理: ...

  7. jquery插件——仿新浪微博限制输入字数的textarea

    内容链接地址:http://www.cnblogs.com/jone-chen/p/5213851.html: <!DOCTYPE html> <html> <head& ...

  8. 使用钉钉对接禅道的bug系统,实现禅道提的bug实时在钉钉提醒并艾特对应的开发人员处理

    现在公司测试中有一个痛点是每次测试人员提完bug后,需要定期去提醒开发人员查看禅道的bug记录及修复bug. 导致测试人员在项目测试中不仅要测试整个软件,还要负起实时监督提醒功能的“保姆角色”,身心疲 ...

  9. 【Android Studio】类名字右下角红色的 J 【待解决】

    问题如下图所示: 正在寻找结解决方法--

  10. SWT 注意事项

    一:GridData (1) 将 GridData 的 widthHint 设置为0,可以解决控件大小会随着这其默认值长度大小而改变的问题.