Re: [问题] 缩减程式码以及PANDAS问题

楼主: TuCH (谬客)   2021-04-20 08:41:02
先稍微整理一下
※ 引述《MAGICXX (逢甲阿法)》之铭言:
: 大家好
: 1.
: 我现在有一组程式码有问题
: upperb=NDVI_LST[col[0]]>0.0
: lowerb=NDVI_LST[col[0]]<0.1
: edge_1=NDVI_LST[(upperb & lowerb)]
col_0 = col[0]
col_1 = col[1]
upperb=NDVI_LST[col_0]>0.0
lowerb=NDVI_LST[col_0]<0.1
edge_1=NDVI_LST[(upperb & lowerb)]
: lst_values=[]
: for i in edge_1[col[0]]:
: LST=NDVI_LST.loc[NDVI_LST[col[0]]==i,col[1]]
: NDVI=i # 这行不知道在干嘛
: for j in LST.values:
: lst_values.append(j)
: df.loc[0.0,'w1月']=max(lst_values)
# 这段看不懂在干嘛
max_lst_values = edge_1[col_1].max()
min_lst_values = edge_1[col_1].min()
: lst_values=[]
: for i in edge_1[col[0]]:
: LST=NDVI_LST.loc[NDVI_LST[col[0]]==i,col[1]]
: NDVI=i
: for j in LST.values:
: lst_values.append(j)
: df.loc[0.0,'d1月']=min(lst_values)
: 因为我现在会需要有12个月的重复计算以及
: upperb以及lowerb的重复计算(0.0 ,0.1, 0.2, 0.3.....1.0)
: 原本我是用下面的code跑 可是每次都会剩下最后一个值然后把前面的值盖掉
: NDVI_bound=np.around(np.linspace(0,1,11).tolist(),decimals=2)
: for k in range(1,13):
: for j in range(23):
: for i in range(10):
: upperb=NDVI_LST[col[int(j)]]>NDVI_bound[int(i)]
: lowerb=NDVI_LST[col[int(j)]]<NDVI_bound[int(i)+1]
: edge_1=NDVI_LST[(upperb & lowerb)]
: lst_values=[]
: for l in edge_1[col[int(j)]]:
: LST=NDVI_LST.loc[NDVI_LST[col[int(j)]]==l,col[int(j)+1]]
: NDVI=i
: for m in LST.values:
: lst_values.append(m)
: if lst_values==[]:
: df.loc[NDVI_bound[int(i)+1],'w'+str(k)+'月']=0
: df.loc[NDVI_bound[int(i)+1],'d'+str(k)+'月']=0
: else:
: df.loc[NDVI_bound[int(i)+1],'w'+str(k)+'月']=max(lst_values)
: df.loc[NDVI_bound[int(i)+1],'d'+str(k)+'月']=min(lst_values)
: 我想问一下大家 这样要怎么缩减这个程式码才会是对的?
: 不然我光是用一个一个贴 就要2000多行程式码 可是明明是重复做一样的动作...
这边完全没有对K做操作 请检查一下code跟逻辑
: 2.查表
: 我找的值是从上面那张表出来的
: D1 W1
: 0.1 23.7 22.4
: 0.2 25.8 26.88
: 0.3 29.8 30.64
: .
: .
: .
: 1.0 35.26 38.31
: 我现在给他一个值 他要怎么找到在这张表的哪个范围?
: 比如说 我现在给他27.33这个数值 他要怎么找到是在0.2~0.3之间
: 然后跟我说上限是29.8 下限是25.8 这样?
: 有两个问题 再麻烦各位了QQ
binary search
作者: MAGICXX (逢甲阿法)   2021-04-20 10:09:00
那个K是月份 在最后面那边有用到K喔
楼主: TuCH (谬客)   2021-04-20 16:48:00
只有在存的时候用到 那不是每次都一样吗

Links booklink

Contact Us: admin [ a t ] ucptt.com