python笔记

Numpy

切片

选择均匀间隔的元素/选择奇数偶数列

x = numpy.array([[ 1,  2,  3,  4,  5],
[ 6,  7,  8,  9, 10],
[11, 12, 13, 14, 15],
[16, 17, 18, 19, 20],
[6,  7,  8,  9, 10]])
#间隔三行取行数组
a=x[::4]
#a= [[1	2 3	4 5]
# [6 7 8 9 10]]


#间隔三列取列数组
b=a[:,::4]
# b = [[1	5]
#      [6	10]]

忽略0

a = numpy.array([0,1,2,0,2,3,4])
b = a[numpy.nonzero(a)]

where & mask

mask = np.where( (array_xya[:,1]> array_xya[:,1].max()-200 ) & (array_xya[:,0]>0.6) )
array = array_xya[mask]
#数组长度:array.shape[0]

np.array_split()与np.split()

np.array_split()可以进行不均等的划分,而np.split()只能进行均等划分。

import numpy as np
x = np.arange(8.0)

print np.array_split(x,3)
#输出:不均等划分结果
    [array([ 0.,  1.,  2.]), array([ 3.,  4.,  5.]), array([ 6.,  7.])]
print np.split(x,3)
#报错:一旦不均等就会报错
    'array split does not result in an equal division')
    ValueError: array split does not result in an equal division

求导,曲率计算

dx= np.gradient(x)
dy = np.gradient(y)
d2x = np.gradient(dx)
d2y = np.gradient(dy)
curvature = (np.abs(dx * d2y - d2x * dy) / (dx * dx + dy * dy)**1.5)*1000

文件读取

rasterio

import rasterio
Raster= "C:\\Users\\a\\Downloads\\2015.tif"	#多波段tif
with rasterio.open(Raster) as src:
     array = src.read()
array1 = array[0,::]	#第一个波段

读取文件夹下的子文件夹里的文件

import os
def get_filelist(dir):
    Filelist = []
    for home, dirs, files in os.walk(input_folder):
        for filename in files:
            # 文件名列表,包含完整路径
            Filelist.append(os.path.join(home, filename))
            # # 文件名列表,只包含文件名
            # Filelist.append( filename)
    return Filelist

if __name__ == "__main__": 
    input_folder = '....'
    file_list = get_filelist(input_folder)

平滑+拟合

loess平滑

f =0.35
yest = lowess_ag(x, y, f=f, iter=4)#拟合的y值

高斯拟合

H, A, x0, sigma = gauss_fit(x, y) #拟合的公式
# GaussLine = sigma*2.58+x0   
GaussLine = sigma*1.96+x0

Matplotlib

matplotlib图库

plt.scatter(array[:,1],array[:,0],color='red', marker='.',label='original values')
if line!=-9999:
    plt.plot([line,line],[0,0.8],color = 'blue')
plt.xlabel('dem')
plt.ylabel('ndvi')
plt.title('line')
plt.legend(loc=3) 
plt.show()    
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
### 回答1: Python笔记.md 是一个用于记录Python编程相关内容的markdown文档。 在Python学习过程中,学习者通常会遇到各种问题和疑惑,需要有一个地方来记录学习笔记和重要概念,以方便日后复习和查阅。Python笔记.md 就是一个很好的选择。 Python笔记.md 可以按照自己的需要来组织内容,比如可以分为不同的章节或主题,并使用markdown语法来格式化文档,使其更加清晰易读。 在Python笔记.md中,可以记录Python的基础语法、常用数据结构、函数、类、模块等内容。此外,还可以记录一些常见的错误和解决方法,以便日后遇到类似问题时能够快速找到解决方案。 Python笔记.md 还可以用来记录自己的思考和理解。在学习过程中,我们常常会思考某个概念或代码背后的原理,这时候可以将自己的思考记录在笔记中,以便后续复习和回顾。 使用Python笔记.md 还可以方便与他人分享学习心得。可以在文档中加入注释或标题,使得文档更加易读和友好。同时,也可以将Python笔记.md 推送到版本控制系统中,与他人共享和共同编辑。 总之,Python笔记.md 是一个非常有用的工具,可以帮助学习者系统地记录、整理和复习Python编程相关的知识和经验。无论是初学者还是有经验的开发者,都可以从中受益,并提高自己的编程技能。 ### 回答2: Python笔记.md是一个使用Markdown语法编写的Python笔记文档。Markdown语法是一种轻量级的标记语言,可以快速地编辑和排版文档。 在Python笔记.md中,可以记录Python程序设计的相关知识、概念和技巧。通过使用Markdown语法,可以方便地插入代码块、链接、图片以及其他强调和排版格式,使得笔记更加直观和易读。 Python笔记.md可以按照不同的章节和主题组织内容,方便快速查找和阅读。在每个章节中,可以记录不同的Python编程概念,如数据类型、控制结构、函数、类等。可以通过示例代码和解释说明来详细解释这些概念的用法和特点。 在笔记中,还可以记录一些Python的常见问题和解决方案,例如常见错误、调试技巧等。这些内容可以帮助初学者更好地理解和掌握Python语言。 此外,Python笔记.md还可以连接到其他的Python资源,如官方文档、教程、在线代码编辑器等。这样可以提供更多的学习和参考资料。 总之,Python笔记.md是一个有条理、易读和方便编辑的Python学习笔记文档,可以帮助人们更好地学习和理解Python编程语言。 ### 回答3: Python笔记md是一种用来记录Python编程语言相关内容的文本文件格式。它使用Markdown语法来快速、简洁地编写和格式化笔记Python笔记md的优点是: 1. 简单易懂:Markdown语法简洁明了,使用起来非常简单,即便没有编程背景的人也能快速上手。 2. 跨平台兼容:无论是在Windows、Mac还是Linux系统中,Python笔记md都可以轻松使用。 3. 可读性强:Python笔记md的文本格式使得代码和说明可以同时显示,方便读者理解和学习。 4. 方便分享和发布:Python笔记md可以导出为HTML或PDF格式,方便分享给其他人或者发布到网络上。 5. 与开发工具兼容:大多数集成开发环境(IDE)和文本编辑器都支持Markdown语法,可以实时预览和编辑笔记。 使用Python笔记md可以帮助程序员记录代码和相关的解释和说明,方便复习和查看。它还可以用于编写技术博客、文档和教育材料等。而且由于其文本格式的特点,Python笔记md也非常适合使用版本控制系统进行版本管理。 总而言之,Python笔记md是一种简单、灵活且易于分享的笔记格式,可以有效提高编程学习和开发的效率。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Prophet.Z

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值