当前位置: 首页 > 后端技术 > PHP

猎人猎人夹机器人互换自动交易机器人哈希竞猜农场吐司游戏LP流动性节点质押智能合约合约量化(案例讲解)

时间:2023-03-29 20:58:35 PHP

1.重复元素判断下面的方法可以检查给定列表是否有重复元素,它将使用set()函数来删除所有重复元素。defall_unique(lst):返回len(lst)==len(set(lst))x=[1,1,2,2,3,2,3,4,5,6]y=[1,2,3,4,5]all_unique(x)#Falseall_unique(y)#True2。Blocking给定一个特定的大小,定义一个函数根据这个大小来切割列表。frommathimportceildefchunk(lst,size):returnlist(map(lambdax:lst[xsize:xsize+size],list(range(0,ceil(len(lst)/size)))))chunk([1,2,3,4,5],2)[[1,2],[3,4],5]3.Compression这种方法可以去除布尔值,例如(False,None,0,""),它使用filter()函数。defcompact(lst):returnlist(filter(bool,lst))compact([0,1,False,2,'',3,'a','s',34])[1,2,3,'a','s',34]4。使用枚举我们经常使用For循环来遍历一个列表,我们也可以枚举列表的索引和值。list=["a","b","c","d"]forindex,elementinenumerate(list):print("Value",element,"Index",index,)('Value','a','Index',0)('Value','b','Index',1)('Value','c','Index',2)('Value','d','Index',3)\5。解包以下代码段可以将打包对列表解包为两个不同的元组。array=[['a','b'],['c','d'],['e','f']]transposed=zip(*array)print(transposed)[('a','c','e'),('b','d','f')]6.展开列表此方法将递归地将列表的嵌套展开为单个列表。defspread(arg):ret=[]foriinarg:ifisinstance(i,list):ret.extend(i)else:ret.append(i)returnretdefdeep_flatten(lst):result=[]result。扩展(传播(列表(地图(lambdax:deep_flatten(x)如果类型(x)==listelsex,lst))))返回结果deep_flatten([1,[2],[[3],4],5])#[1,2,3,4,5]7.列表的差异该方法将返回第一个列表中不在第二个列表中的元素。如果要同时反馈第二个列表的唯一元素,需要加一句set_b.difference(set_a)。defdifference(a,b):set_a=set(a)set_b=set(b)comparison=set_a.difference(set_b)returnlist(comparison)difference([1,2,3],[1,2,4])#[3]8.执行时间下面的代码块可以用来计算执行一段特定代码所花费的时间。importtimestart_time=time.time()a=1b=2c=a+bprint(c)#3end_time=time.time()total_time=end_time-start_timeprint("Time:",total_time)('Time:',1.1205673217773438e-05)9.Shuffle该算法会打乱列表元素的顺序,主要通过Fisher-Yates算法对新列表进行排序:fromcopyimportdeepcopyfromrandomimportrandintdefshuffle(lst):temp_lst=deepcopy(lst)m=len(temp_lst)while(m):m-=1i=randint(0,m)temp_lst[m],temp_lst[i]=temp_lst[i],temp_lst[m]返回temp_lstfoo=[1,2,3]shuffle(foo)#[2,3,1],foo=[1,2,3]10、交换值无需额外操作即可交换两个变量的值。defswap(a,b):returnb,aa,b=-1,14swap(a,b)#(14,-1)spread([1,2,3,[4,5,6],[7],8,9])[1,2,3,4,5,6,7,8,9]