Flask接口签名sign原理与实例代码浅析
287
2022-06-10
Python作为一门新型的编程语言(一般常用作脚本语言)很受欢迎,毕竟相对其他的编程语言(Java ,C#等)来说比较容易入手。那么,在刚开始学习Python时有哪些疑难点需要掌握呢?以下是小编为你整理的python入门后学什么
list:列表。关于列表主要有创建、访问、添加、删除和替换几方面来看。
创建:L=[1,2,3,4,5]
访问:分按照索引访问和倒序访问。前者:L[0]=1,L[4]=5;后者:L[-1]=5,L[-5]=1
添加:
1,直接在最后添加:L.append()
例如:L.append(6)则L=[1,2,3,4,5,6]
2. L.insert()这个需要输入两个参数(前面参数是索引号,后面是新元素),例如L.insert(0,8)则L=[8,1,2,3,4,5]
3,删除:
L.pop(),这个是删除最后一个元素;如果删除某个位置的元素,只需要在()中输入索引号即可。如:L.pop(0)则L=[2,3,4,5]
4,替换:
想替换哪个位置的元素,只需要L[xx]其中xx就是替换的元素的索引号。例如:
L[1]='Adam'则L=[1,'Adam',3,4,5]
2
tuple:元组。创建tuple例如:t=(1,2,3)
注意:单元素的tuple必须要在元素后面添加“,”,例如:t=(1,)
查看tuple只需要t[xx]其中xx表示元素的索引号。
tuple是不可变的,一旦创建便不可修改。
3
dict:字典。关于dict主要有创建、访问、添加和遍历几方面来看。
创建:dict={'A':1,'B':2,'C':3}前面的为Key后面的问Value,dict就是有Key:Value组合成的。可以通过Key来查找Value。
访问:d[key]访问时必须保证key是在dict中的。例如:print d['A']=1;key在不在dict中需要判断(一般都使用dict提供的get方法即可),例如:print d.get('A')返回1;如果输入的key不存在dict中,那么print d['p']返回的是None。
注意:dict的特点:无序,key必须是不可变。
更新(添加):直接用赋值语句即可。例如:d['M']=4则print d返回的可能是{''C':3,'M':4,A':1,'B':2}因为dict是无序的,所以返回的顺序也是不确定的。
遍历:dict={'A':1,'B':2,'C':3使用for即可
for key in d:
print key
则返回的是对应的key值:
A
B
C
变量的应用
首先看变量(实际是对象引用,只是大家在其他语言的影响下,习惯叫变量)
如果2个变量的数值相同,那么必然是地址相同,所以a is b是True(正确的)
解析:a = 123,这时候内存里面没有123这个对象,于是创建了123,当b = 123的时候,内存里面有了123这个对象,于是直接指向123这个对象,这就是Python的特点,变量也是引用对象
当换成元组之后,结果就不一样了,结果是False(不正确)
比如:a = (123,456) b = (123,456)
解析:a是指向一个元组,b是指向一个元组,这些元组分别有自己的内存地址,然后这些元组里面的元素再分别指向其他对象
但是具体到某一个元素的时候,结果又一样了
比如,a = (123,456) b = (123,456),比较,a[0] 与 b[0]
解析:当具体指向某一个元素的时候,实际指向这个元素指向的对象
注意:当元组只有一个元素的时候,创建的不是元组(列表就不一样了,如图2)
如:a = (123),那么a的类型的int,不是元组类型
关于==符号
python的==是比较值是否相同,不是比较内存是否相同
比如:a =(123,456) b =(123,456),而a==b则是True,a is b是Flash
查看内存地址,用id()
说了这么多,is是比较内存地址,那么人眼比较可以直接打印出内存地址
比如:a = 123,id(a)则是获取a的内存地址
输出方法
输出无外乎就是将想要打印的东西或者结果打印出来,即为输出
使用print()函数进行输出
打印字符串
可以在括号中加上引号引起来的字符打印输出
例如输出test,代码实现如下
print('test')
当然也可以打印多个字符串
例如输出'test , ','hello world!'
可以次用逗号分割,就可以连接在一起输出到屏幕
print('test , ','hello world!')
稍作说明:print()会依次打印每个字符串,遇到逗号就会输出一个空格,这样子字符串就连成一片输出来喽。
还可以打印整数(数值型的)
例如
print(250)
当还可以将数值跟字符一起输出来
例如:算一个250+250
print(250+250)
输出的更漂亮一些,可以这样
print('205 + 250 = ' , 250+250)
urllib.request
urllib.request 模块期初是用来打开和获取 URL 的。让我们看看你可以用函数 urlopen 可以做的事:
>>> import urllib.request >>> url = urllib.request.urlopen('https://google.com/') >>> url.geturl() 'https://google.com/' >>> url.info() >>> header = url.info() >>> header.as_string() ('Date: Fri, 24 Jun 2016 18:21:19 GMT/n' 'Expires: -1/n' 'Cache-Control: private, max-age=0/n' 'Content-Type: text/html; charset=ISO-8859-1/n' 'P3P: CP="This is not a P3P policy! See ' 'https://google.com/support/accounts/answer/151657?hl=en for more info."/n' 'Server: gws/n' 'X-XSS-Protection: 1; mode=block/n' 'X-Frame-Options: SAMEORIGIN/n' 'Set-Cookie: ' 'NID=80=tYjmy0JY6flsSVj7DPSSZNOuqdvqKfKHDcHsPIGu3xFv41LvH_Jg6LrUsDgkPrtM2hmZ3j9V76pS4K_cBg7pdwueMQfr0DFzw33SwpGex5qzLkXUvUVPfe9g699Qz4cx9ipcbU3HKwrRYA; ' 'expires=Sat, 24-Dec-2016 18:21:19 GMT; path=/; domain=.google.com; HttpOnly/n' 'Alternate-Protocol: 443:quic/n' 'Alt-Svc: quic=":443"; ma=2592000; v="34,33,32,31,30,29,28,27,26,25"/n' 'Accept-Ranges: none/n' 'Vary: Accept-Encoding/n' 'Connection: close/n' '/n') >>> url.getcode() 200
在这里我们包含了需要的模块,然后告诉它打开 Google 的 URL。现在我们就有了一个可以交互的 HTTPResponse 对象。我们要做的第一件事是调用方法 geturl ,它会返回根据 URL 获取的资源。这可以让我们发现 URL 是否进行了重定向。 接下来调用 info ,它会返回网页的元数据,比如请求头信息。因此,我们可以将结果赋给我们的 headers 变量,然后调用它的方法 as_string 。就可以打印出我们从 Google 收到的头信息。你也可以通过 getcode 得到网页的 HTTP 响应码,当前情况下就是 200,意思是正常工作。
如果你想看看网页的 HTML 代码,你可以调用变量 url 的方法 read。我不准备再现这个过程,因为输出结果太长了。
请注意 request 对象默认发起 GET 请求,除非你指定了它的 data 参数。如果你给它传递了 data 参数,这样 request 对象将会变成 POST 请求。部分内容选自《Linux就该这么学》感兴趣的可以看下哦
版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。
发表评论
暂时没有评论,来抢沙发吧~