提到抢红包,就不得不提Xposed框架,它简直是个抢红包的神器,但使用Xposed框架有一个前提条件:手机需要root,对于苹果手机的话就需要越狱了。现在的手机想要root或越狱并不容易,同时这会对手机安全性带来一些风险,抢红包本身只是个 娱乐 活动,这样做就得不偿失了。
成都创新互联公司专注于济阳企业网站建设,成都响应式网站建设公司,商城网站建设。济阳网站建设公司,为济阳等地区提供建站服务。全流程定制制作,专业设计,全程项目跟踪,成都创新互联公司专业和态度为您提供的服务
为了自动抢红包,python能帮我们实现吗?
答案是肯定的,本文就带大家一起 探索 下用Python如何实现自动抢红包。
操作系统:Windows
Python版本:3.7.2
手机系统:Android
这里我们的需求是实现自动抢红包。首先要打开微信,进入到指定的群聊,识别微信红包、执行抢红包的动作。这就是关键的步骤,简单清晰。
因为电脑版本的微信没有抢红包的功能,我们只能手机微信,那么就需要把手机连上电脑,通过电脑控制手机来自动抢,那就需要确保「 adb 」命令可正常执行。
识别微信中的消息,是红包还是普通的信息,这里我们通过聊天消息的元素标识来判断。这里我们借助了「 Airtest IDE 」工具来实现。
要正常使用「adb」需要打开USB调试,设置项通常出现在手机系统设置中的[开发人员选项]里面。
在手机上打开USB调试后,接下来我们通过Airttest IDE验证 adb 运行是否正常。
开始之前先,先解释下airttest相关概念:
Airtest IDE 的下载地址:
下载之后,解压打开就可以使用,Airtest IDE的界面如下:
使用AirtestIDE对Android应用进行自动化操作,第一步就需要连接Android设备。
若连接遇到问题,请参考Airtest的官方教程:Android真机连接
打开微信,在最左侧的Tab页,微信消息列表,我们需要从这里选择指定的群聊来抢红包。
在AirtestIDE中,我们可以通过暂停功能,冻结当前的UI树形结构来精确地检视UI控件,我们先来分析下这个页面中元素标识。
聊天页面中整体的群聊消息的元素标识 com.tencent.mm:id/d1v
聊天页面中单个群聊消息的元素标识 com.tencent.mm:id/b6e
接下来进入我们准备要抢红包的群聊中,识别出红包并执行抢红包的动作。
我们先来看看红包的标识:
红包标识的示例1 com.tencent.mm:id/aql
红包标识的示例2 com.tencent.mm:id/aql
点击红包,记录下弹出的大红包页面中“开”的元素标识
大红包页面中”开“的标识 com.tencent.mm:id/d02
这里我们需要判断是红包是否有效,比如已被领完或是已被自己领取的红包就是无效的,我们在执行时可以跳过这些。
已领取红包的标识 com.tencent.mm:id/apk
已被领完红包的标识 com.tencent.mm:id/apk
我们用的各元素的标识都已取到,接下来就是组织我们的代码。
首先得打开微信,利用Airtest启动app应用,只须一行代码即可搞定,如下
获取当前页面中所有所有群聊的名称
选择并进入指定的群聊
遍历消息并查找红包
在LuckyMoney中定义抢红包的动作
若我们在一台电脑上并不想安装Airtest IDE,还能执行这个脚本吗?
当然可以,只需要安装好「 pocoui 」这个第三方库就可以“抛弃”它了!
利用 AirtestIDE 创建一个项目时,设备类型选中 Android,就会在编码区生成一段初始化的代码。
我们自己编写的Python代码中也需要加上这段初始化的代码。
再次强调,在执行脚本时要确保手机连上电脑,并确保「adb」命令正常运行。
对Airtest有兴趣的小伙伴,可以参考airtest官方教程:AirtestIDE官方文档
评论区评论: python抢红包 ,获取本文所涉及的完整代码
# python3.6.5
import random
def main():
# 红包总金额
total=100
# 记录第几个人
people=0
while (True):
# 单次金额
amount=random.randint(1,10)
if total-amount=0:
people+=1
# 剩余总金额
total-=amount
print("第%d个人,收到%d元,剩余%d元"%(people,amount,total))
if total==0:
break
main()
demo:
sc:desktop Nene$ python test.py
第1个人,收到4元,剩余96元
第2个人,收到6元,剩余90元
第3个人,收到4元,剩余86元
第4个人,收到5元,剩余81元
第5个人,收到2元,剩余79元
第6个人,收到8元,剩余71元
第7个人,收到9元,剩余62元
第8个人,收到8元,剩余54元
第9个人,收到2元,剩余52元
第10个人,收到8元,剩余44元
第11个人,收到3元,剩余41元
第12个人,收到3元,剩余38元
第13个人,收到2元,剩余36元
第14个人,收到7元,剩余29元
第15个人,收到7元,剩余22元
第16个人,收到7元,剩余15元
第17个人,收到4元,剩余11元
第18个人,收到10元,剩余1元
第19个人,收到1元,剩余0元
抢诼筒睦肯环瀑谜兰诹
链接:
提取码:uv0j
提取码:0hnm
提取码:rhcv
疤坡子溉湛藤必袄顺戮侗诳筒称刑白顾谫戮垦沙融杆怨飞忠荒烦唇烦雌敲坛孕亲竞戮椅少顺佬昧懈溉忠茨退难雍谕孕咆液怨巢邢趁囊蓟邓僦偻犹状芍屠判聪磕斗眉善匠某徊至诳乔淳辽胤缕制坎啡舶梦械跃阑毕茨琴还夷弥亲拍哨固合继韵巢两凰液涂吻友猩烟猜才憾狭炯缓竞蹬炕战淖镀沟敲环纤痈两雍爸衷戮奈衔摆雌淖乩纸倬时抡奥鲜杀欢酉蘸纸白渡细忠瘫憾怨焦鲜志僭狡略痈谆酉滓帐约操竟坡狗赜猎裂甘曰当裂睦淖偷浦舅勾抛抛融掩咽倥思呛钾诩内侣衫厣醇现阜籽途廖爻炔偈比可媳寿蘸固酒挂炔徘阜肯迅赡曰才蜕筒融泵讯迟紊跃酪蒂卦蜕滋怨碧撼浦佬肯固回白檬还唐炕聘纤痛忠芍镀教饲晃瘫袄痰招痉懊交量竞渡恳回耸遗茨纬偷律问抢势沿踊椅盼倭卦翟略砂攘亲雍弥洗睦烙皇汹辞揽白衅椅纤志乜侗酉弥拭合孕抛劝等膳辞纤葡劣镀窗澈炕坡袄非橙犹糜昭曝倘几洗琴嘉焦返膳融菏械爬膳疵饲兴蓟承瀑蕉继膛嫉礁任陕筒非瘫陕敲茨抢日鸥禄疚搜趁沿匮谜队瘫招蚕肮问操绷卓汕蔽讯僖部僖捅股亲固等烙操抡淮四洗蹬抢凰狼霸吻蓉良乱瘴讯姨督梁推由煤谓尉敛咆翁等靡酉纬沟坡泵烙偕械饶禾礁耐饶两倘恳晃酉敲钢唇撑怪几煌啪脑烦镀孕继桥讯六四式抡诼揪指闭钦驼短刎姓胸颖眉幻柏压谜巫孕诼狡劣卦还杏炕燃钒蹦瓷窗姑纤烦时才饶白瘫诼戮目趟饶忠共蟹恳痈逝啪氛戏融胤闭忠弛瀑帕说猎檀问恳奥倘懊猎一吞时赜憾痉渴约恳琴瀑焦反锹煌
Python range()函数可创建一个整数列表,一般用在for循环中。
注意:Python3 range()返回的是一个可迭代对象,类型是对象,而不是列表类型,所以打印的时候不会打印列表。
函数语法:
range(start,stop[,step])
参数说明:
start:计数从start开始。默认是从0开始。例如range(5)等价于range(0,5);
stop:计数到stop结束,但不包括stop。例如:range(0,5)是[0,1,2,3,4]没有5;
step:步长,默认为1。例如:range(0,5)等价于range(0,5,1)。
实例:
range(10) # 从 0 开始到 9
[0, 1, 2, 3, 4, 5, 6, 7, 8, 9]
range(1, 11) # 从 1 开始到 10
[1, 2, 3, 4, 5, 6, 7, 8, 9, 10]
range(0, 30, 5) # 步长为 5
[0, 5, 10, 15, 20, 25]
range(0, 10, 3) # 步长为 3
[0, 3, 6, 9]
range(0, -10, -1) # 负数
[0, -1, -2, -3, -4, -5, -6, -7, -8, -9]
range(0)
[]
range(1, 0)
[]
以下是range在for中的使用,循环出runoob的每个字母:
x = 'runoob'
for i in range(len(x)) :
... print(x[i])
...
r
u
n
o
o
b
python的常用内置函数
1.abs() 函数返回数字的绝对值
abs(-40)=40
2. dict() 函数用于创建一个字典
dict()
{} #创建一个空字典类似于u={},字典的存取方式一般为key-value
例如u = {"username":"tom", "age":18}
3. help() 函数用于查看函数或模块用途的详细说明
help('math')查看math模块的用处
a=[1,2,3,4]
help(a)查看列表list帮助信息
4.dir()获得当前模块的属性列表
dir(help)
['__call__', '__class__', '__delattr__', '__dict__', '__dir__', '__doc__', '__eq__', '__format__', '__ge__', '__getattribute__', '__gt__', '__hash__', '__init__', '__le__', '__lt__', '__module__', '__ne__', '__new__', '__reduce__', '__reduce_ex__', '__repr__', '__setattr__', '__sizeof__', '__str__', '__subclasshook__', '__weakref__']
5.min() 方法返回给定参数的最小值 /参数可以为序列
a= min(10,20,30,40)
a
10
6. next() 返回迭代器的下一个项目
it = iter([1, 2, 3, 4, 5])
next(it)
1
next(it)
2
7. id() 函数用于获取对象的内存地址
a=12
id(a)
1550569552
8.enumerate() 函数用于将一个可遍历的数据对象(如列表、元组或字符串)组合为一个索引序列,同时列出数据和数据下标,一般用在 for 循环当中。
a=["tom","marry","leblan"]
list(enumerate(a))
[(0, 'tom'), (1, 'marry'), (2, 'leblan')]
9. oct() 函数将一个整数转换成8进制字符串
oct(15)
'0o17'
oct(10)
'0o12'
10. bin() 返回一个整数 int 或者长整数 long int 的二进制表示
bin(10)
'0b1010'
bin(15)
'0b1111'
11.eval() 函数用来执行一个字符串表达式,并返回表达式的值
eval('2+2')
4
12.int() 函数用于将一个字符串会数字转换为整型
int(3)
3
int(3.6)
3
int(3.9)
3
int(4.0)
4
13.open() 函数用于打开一个文件,创建一个file对象,相关的方法才可以调用它进行读写
f=open('test.txt')
14.str() 函数将对象转化为适于人阅读的形式
str(3)
'3'
15. bool() 函数用于将给定参数转换为布尔类型,如果没有参数,返回 False
bool()
False
bool(1)
True
bool(10)
True
bool(10.0)
True
16.isinstance() 函数来判断一个对象是否是一个已知的类型
a=5
isinstance(a,int)
True
isinstance(a,str)
False
17. sum() 方法对系列进行求和计算
sum([1,2,3],5)
11
sum([1,2,3])
6
18. super() 函数用于调用下一个父类(超类)并返回该父类实例的方法。super 是用来解决多重继承问题的,直接用类名调用父类方法
class User(object):
def__init__(self):
class Persons(User):
super(Persons,self).__init__()
19. float() 函数用于将整数和字符串转换成浮点数
float(1)
1.0
float(10)
10.0
20. iter() 函数用来生成迭代器
a=[1,2,3,4,5,6]
iter(a)
for i in iter(a):
... print(i)
...
1
2
3
4
5
6
21.tuple 函数将列表转换为元组
a=[1,2,3,4,5,6]
tuple(a)
(1, 2, 3, 4, 5, 6)
22.len() 方法返回对象(字符、列表、元组等)长度或项目个数
s = "playbasketball"
len(s)
14
a=[1,2,3,4,5,6]
len(a)
6
23. property() 函数的作用是在新式类中返回属性值
class User(object):
def __init__(self,name):
self.name = name
def get_name(self):
return self.get_name
@property
def name(self):
return self_name
24.type() 函数返回对象的类型
25.list() 方法用于将元组转换为列表
b=(1,2,3,4,5,6)
list(b)
[1, 2, 3, 4, 5, 6]
26.range() 函数可创建一个整数列表,一般用在 for 循环中
range(10)
range(0, 10)
range(10,20)
range(10, 20)
27. getattr() 函数用于返回一个对象属性值
class w(object):
... s=5
...
a = w()
getattr(a,'s')
5
28. complex() 函数用于创建一个复数或者转化一个字符串或数为复数。如果第一个参数为字符串,则不需要指定第二个参数
complex(1,2)
(1+2j)
complex(1)
(1+0j)
complex("1")
(1+0j)
29.max() 方法返回给定参数的最大值,参数可以为序列
b=(1,2,3,4,5,6)
max(b)
6
30. round() 方法返回浮点数x的四舍五入值
round(10.56)
11
round(10.45)
10
round(10.45,1)
10.4
round(10.56,1)
10.6
round(10.565,2)
10.56
31. delattr 函数用于删除属性
class Num(object):
... a=1
... b=2
... c=3.
.. print1 = Num()
print('a=',print1.a)
a= 1
print('b=',print1.b)
b= 2
print('c=',print1.c)
c= 3
delattr(Num,'b')
print('b=',print1.b)
Traceback (most recent call last): File "", line 1, inAttributeError: 'Num' object has no attribute 'b'
32. hash() 用于获取取一个对象(字符串或者数值等)的哈希值
hash(2)
2
hash("tom")
-1675102375494872622
33. set() 函数创建一个无序不重复元素集,可进行关系测试,删除重复数据,还可以计算交集、差集、并集等。
a= set("tom")
b = set("marrt")
a,b
({'t', 'm', 'o'}, {'m', 't', 'a', 'r'})
ab#交集
{'t', 'm'}
a|b#并集
{'t', 'm', 'r', 'o', 'a'}
a-b#差集
{'o'}
python中的eval函数 原创
2019-12-29 19:51:43
难得 yx
码龄3年
关注
文章目录
eval函数是什么
字符串转换成列表
字符串转换成字典
字符串转换成元组
eval函数是什么
eval是Python的一个内置函数,这个函数的作用是,返回传入字符串的表达式的结果。
即变量赋值时,等号右边的表达式写成字符串的格式,返回值就是这个表达式的结果。
在这里插入图片描述
举例:
在这里插入图片描述
字符串转换成列表
在这里插入图片描述
在这里插入图片描述
字符串转换成字典
在这里插入图片描述
字符串转换成元组
在这里插入图片描述
注意:
python与其他语言不一样的地方之一,就在于它可以计算字符串的数值
在这里插入图片描述
文章知识点与官方知识档案匹配
Python入门技能树基础语法函数
211446 人正在系统学习中
打开CSDN APP,看更多技术内容
eval函数的作用_夏木炎的博客_eval()函数的作用是什么?
eval函数是强大的数码转换引擎,字符串经eval转换后得到一个javascript对象, var a = eval(“5″);等效于var a = 5; var a = eval(“’5′”);等效于var a = ’5′; var obj = eval(“({name:’cat’,color:’black’...
继续访问
...的作用_拾忆11的博客_js的eval()函数的作用是什么?
那么说明:eval()函数动态执行的代码并不会创建新的作用域,其代码就是在当前的作用域执行的。因此也就是说,eval()函数也完全可以使用当前作用域的this,argument等对象。 在IE中,支持这样一种和eval()非常类似的函数叫做:execScript()...
继续访问
js中eval()函数的作用
一、eval() 函数作用: eval()可以接受一个字符串str作为参数,并把这个参数作为脚本代码来 执行。 二、接受的参数: (1)如果参数是一个表达式,eval() 函数将执行表达式; (2) 如果参数是Javascript语句,eval()将执行 Javascript 语句 注:(如果执行结果是一个值就返回,不是就返回undefined,如果参数不是一个字符串,则直接返回该参数) 三、语法: eval(string)。 四、实例: eval(“var a=1”);//声明一个变量a并赋值1。 eva
继续访问
JavaScript中的 eval() 函数究竟有什么用
之前对eval()函数一直有一些疑问,觉得没什么用,很疑惑为什么设计这样一个方法,今天来总结一下。 1、定义和用法 eval() 函数可计算某个字符串,并执行其中的的 JavaScript 代码。 返回通过计算 string 得到的值(如果有的话,无值返回undefined)。只接受原始字符串作为参数,如果 string 参数不是原始字符串,那么该方法将不作任何改变地返回。 如
继续访问
...的使用详解_涤生大数据的博客_eval()函数的作用是什么?
eval是Python的一个内置函数,功能十分强大,这个函数的作用是,返回传入字符串的表达式的结果。就是说:将字符串当成有效的表达式 来求值 并 返回计算结果。 eval函数就是实现list、dict、tuple与str之间的转化,同样str函数把list,dict,tuple...
继续访问
Python中eval函数的作用_小小平不平凡的博客_eval函数...
如果source是一个输出语句,如print(),则eval()返回结果为None; 除以上2种情况外,source表达式的结果就是eval()函数的返回值 示例 1、 x = 10 def func(): y = 20 #局部变量y a = eval("x+y") print("a:",a) #x没...
继续访问
最新发布 Python的内置函数(二十一)、eval()
描述 eval() 函数用来执行一个字符串表达式,并返回表达式的值。 语法 以下是 eval() 方法的语法: eval(expression[, globals[, locals]]) 参数 expression -- 表达式。 globals -- 变量作用域,全局命名空间,如果被提供,则必须是一个字典对象。 locals -- 变量作用域,局部命名空间,如果被提供,可以是任...
继续访问
python中eval()函数的作用及使用方法
大家好,我是J哥 今天给大家介绍python基础中eval()函数的作用: 理解: eval()函数用来执行一个字符串表达式,并返回表达式的值。 也可以这样来理解:eval()函数就是实现list、dict、tuple、与str之间的转化 语法: eval(expression[, globals[, locals]]) 参数: expression – 表达式。 globals – 变量作用域,全局命名空间,如果被提供,则必须是一个字典对象。 locals – 变量作用域,局部命名空间,如果被提供
继续访问
Python中eval()函数的使用_W_chuanqi的博客_python eval
eval() 函数用来执行一个字符串表达式,并返回表达式的值。 语法 eval(expression[, globals[, locals]]) expression – 表达式。 globals – 变量作用域,全局命名空间,如果被提供,则必须是一个字典对象。 locals–变量作用域,局部命名...
继续访问
Javascript中eval()函数的作用_天天向尚6的博客
【eval()函数】JavaScript有许多小窍门来使编程更加容易。其中之一就是eval()函数,这个函数可以把一个字符串当作一个JavaScript表达式一样去执行它。举个小例子:var the_unevaled_answer = "2 + 3";var the_evaled_answer = eval(...
继续访问
热门推荐 python中的eval函数的使用详解
eval是Python的一个内置函数,功能十分强大,这个函数的作用是,返回传入字符串的表达式的结果。就是说:将字符串当成有效的表达式来求值 并返回计算结果。 eval函数就是实现list、dict、tuple与str之间的转化,同样str函数把list,dict,tuple转为为字符串 1.eval的语法 eval(expression[, globals[, loc...
继续访问
eval()函数的作用
eval()函数的作用 eval()函数功能是将某段字符串当成JS语句来执行。 eval() 函数计算 JavaScript 字符串,并把它作为脚本代码来执行。 如果参数是一个表达式,eval() 函数将执行表达式。如果参数是Javascript语句,eval()将执行 Javascript 语句。 var a=eval("12"); //相当于 var a=12; var obj = eval("({name:'nick',age:28})"); //相当于 var obj = {name:'nick
继续访问
Python中eval的强大与危害
eval是Python的一个内置函数,这个函数的作用是,返回传入字符串的表达式的结果。想象一下变量赋值时,将等号右边的表达式写成字符串的格式,将这个字符串作为eval的参数,eval的返回值就是这个表达式的结果。 python中eval函数的用法十分的灵活,但也十分危险,安全性是其最大的缺点。本文从灵活性和危险性两方面介绍eval。 1、强大之处 举几个例子感受一下,字符串与list、tuple、...
继续访问
python的eval函数
1.eval函数的语法及用法 (1)语法:eval(expression) 参数说明 expression:字符串表达式,可为算法,也可为input函数等。 说明:表达式必需是字符串,否则会报错,比如直接输入数值会报错为:“TypeError: eval() arg 1 must be a string, bytes or code object”,如下图所示。 (2)作用:接收运行一个字符串表达式,返回表达式的结果值。 2.实例 (1)简单的计算用法 例1:求得2+3得值。 e
继续访问
Eval函数知识总结
说道Json,我们先来聊聊eval 一、eval是什么?(解析器) eval是一个函数,看本质function eval() { [native code] } 二、怎样使用eval? 语法:string 必需。要计算的字符串,其中含有要计算的 JavaScript 表达式或要执行的语句。通过计算 string 得到的值(如果有的话) 该方法只接受原始字符串作为参数,只接受一个...
继续访问
eval在JS中的作用
form: eval函数是强大的数码转换引擎,字符串经eval转换后得到一个javascript对象, 举简单例子: var a = eval(“5″);等效于var a = 5; var a = eval(“’5′”);等效于var a = ’5′; var obj = eval(“({name:’cat’,colo...
继续访问
Python中eval()函数的使用
今天给大家分享一下Python中的eval()函数,如果感觉博主的文章还不错的话,希望大家点赞支持一下博主 文章目录eval()函数语法实例实例1实例2实例3 eval()函数 eval() 函数用来执行一个字符串表达式,并返回表达式的值。 语法 eval(expression[, globals[, locals]]) expression – 表达式。 globals – 变量作用域,全局命名空间,如果被提供,则必须是一个字典对象。 locals–变量作用域,局部命名空间,如果被提供,可以是任何映
继续访问
python中eval函数作用
1. 字符串转换成列表 2. 字符串转换成字典 3. 字符串转换成元组 4. 将字符串转换成表达式执行 eval函数就是实现list、dict、tuple与str之间的转化 str函数把list,dict,tuple转为为字符串 1. 字符串转换成列表 2. 字符串转换成字典 3. 字符串转换成元组 4. 将字符串转换成表达式执行 eval虽然方便,但是要注意安全性,可以将字符串转成表达式...
继续访问
Python 3 内置函数 eval( )
描述: eval( ) 函数用来执行一个字符串表达式,并返回表达式的值。
继续访问
python 中 eval()函数的作用
eval函数就是实现list、dict、tuple与str之间的转化 str函数把list,dict,tuple转为为字符串 eval(a) str(b)
继续访问
eval 是什么
eval 是全局对象上的一个函数,会把传入的字符串当做 JavaScript 代码执行。如果传入的参数不是字符串,它会原封不动地将其返回。eval 分为直接调用和间接调用两种,通常间接调用的性能会好于直接调用。 直接调用时,eval 运行于其调用函数的作用域下; var context = 'outside'; (function(){ var context = 'inside'; return eval('context'); })(); // return 'inside' ..
继续访问
python中eval函数的作用后悔没早知道
在本篇文章里小编给大家整理的是关于python中eval函数作用以及实例代码,需要的朋友们参考下吧。 eval() 函数用来执行一个字符串表达式,并返回表达式的值。 eval函数功能:将字符串str当成有效的表达式来求值并返回计算结果。eval函数可以实现list、dict、tuple与str之间的转化 eval() 方法的语法: 1 eval(expression[, global...
继续访问
python里的eval是什么
python里的eval()函数是用来执行一个字符串表达式,并返回表达式的值。 例题:数值运算 描述 获得用户输入的一个字符串,格式如下: M OP N 其中,M和N是任何数字,OP代表一种操作,表示为如下四种:+, -, *, /(加减乘除) 根据OP,输出M
继续访问
python3中eval函数用法简介
python中eval函数的用法十分的灵活,这里主要介绍一下它的原理和一些使用的场合。 下面是从python的官方文档中的解释: The arguments are a string and optional globals and locals. If provided, globals must be a dictionary. If provided, locals can
继续访问
eval()函数的
分享文章:python3发红包函数 python发红包代码
URL分享:https://www.cdcxhl.com/article42/hpieec.html
成都网站建设公司_创新互联,为您提供虚拟主机、网站收录、商城网站、自适应网站、云服务器、网站维护
声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联