python之路-基础篇-第二周 一、Python解释器: 二、推荐一本书: 三、字符编码: 四、执行脚本传入参数 五、缓存 六、字符串相加与格式化 七、循环 八、python中一切都是对象 九、数据类型介绍
- cpython为默认解释器,由C语言开发,目前使用最为广泛。
- jpython 运行在Java平台上的python解释器,可以直接把Python代码编译成Java字节码执行;与之类似的还有IronPython(.net)
- PyPy解释器,采用JIT技术,对Python代码进行动态编译,所以可以显著提高Python代码的执行速度。
二、推荐一本书:
python源码剖析
三、字符编码:
- 起初,ASCII码,使用一个字节,8位,表示所有内容:256种字符。
表示数字1:00000001 - 后来,万国码,unicode,至少2个字节(16位):65536
表示数字1:0000000000000001 - 再后来,utf-8,对万国码进行按类压缩,优化存放空间
数字1:00000001,8位
汉字:3个字节- 在python2.x中存在转换的问题
unicode -> utf8: encode
utf8 -> unicode: decode - python3.x中不需要考虑此问题
- 在python2.x中存在转换的问题
四、执行脚本传入参数
使用sys.argv传入参数。
import sys
print(sys.argv)
执行结果:
#比如在脚本中传入三个参数,可是同时传入多个参数:
bogon:day02 felo$ python3 ex.py argv1 argv2 argv3
['ex.py', 'argv1', 'argv2', 'argv3']
五、缓存
- 数字:-5到257
>>> a = 1
>>> b = 1
>>> id(a), id(b) #id一致,在缓冲池中
(4297537952, 4297537952)
>>> a = 10000
>>> b = 10000
>>> id(a),id(b) #id不一致,不在缓冲池中
(4316106256, 4316105936)
>>>
- 字符串:按某种权重计算,具体的待查。。。
#
>>> a = 'hello'
>>> b = 'hello'
>>> id(a),id(b)
(4367149744, 4367149744)
六、字符串相加与格式化
- 每次字符串相加,都会在内存中开辟新的空间,尽量不用
>>> print("hello " + "world.")
hello world.
-
使用字符串格式化比较好,可能只创建两次,相对来说更优化一些,建议尽量使用此方法
- %s:格式化字符串
- %d:格式化数字
- %f:格式化浮点数
>>> name = 'felo'
>>> print('my name is %s.' % name)
my name is felo.
>>>
>>> age = 18
>>> print('my name is %s.
my age is %d' % (name,age))
my name is felo.
my age is 18
>>>
七、循环
-
for while (foreach)
-
break;continue;pass;return;exit
- break:退出整个循环
- continue: 退出本次循环
- pass :占位
- return:函数中使用
- exit:程序退出,可以添加退出返回值
八、python中一切都是对象
对象是基于类创建的,所有的功能都是到类中找的。
使用type(a)能够找到类型,或类型所在的位置
九、数据类型介绍
1)数字
int的一些内置方法: *long,float也类似
-
__abs__方法:求绝对值
-
__add__方法:相加
-
__divmod__方法:元组方式返回除法结果取整和余数
-
__eq__方法:判断是否相等,返回布尔值
-
__float__方法:转化为浮点数
-
__floatdiv__方法:地板除,与5//6等价
-
__init__方法:类的构造方法,在创建对象的时候调用
-
__pow__方法:幂
举例:
a = 100
print('divmod 方法:a/7')
print(a.__divmod__(7))
print('
abs方法:a的绝对值')
print(abs(a))
print(a.__abs__())
print('
add方法:a+7')
print(a.__add__(7))
print(a+7)
结果:
divmod 方法:a/7
(14, 2)
abs方法:a的绝对值
100
100
add方法:a+7
107
107
2)字符串
查看类型以及类中成员:
type():返回类名
dir():返回类成员
#例子:
name = 'felo'
print(type(name))
print(dir(name))
执行结果:
<class 'str'> #str类型
#str的类成员
['__add__', '__class__', '__contains__', '__delattr__', '__dir__', '__doc__', '__eq__', '__format__', '__ge__', '__getattribute__', '__getitem__', '__getnewargs__', '__gt__', '__hash__', '__init__', '__iter__', '__le__', '__len__', '__lt__', '__mod__', '__mul__', '__ne__', '__new__', '__reduce__', '__reduce_ex__', '__repr__', '__rmod__', '__rmul__', '__setattr__', '__sizeof__', '__str__', '__subclasshook__', 'capitalize', 'casefold', 'center', 'count', 'encode', 'endswith', 'expandtabs', 'find', 'format', 'format_map', 'index', 'isalnum', 'isalpha', 'isdecimal', 'isdigit', 'isidentifier', 'islower', 'isnumeric', 'isprintable', 'isspace', 'istitle', 'isupper', 'join', 'ljust', 'lower', 'lstrip', 'maketrans', 'partition', 'replace', 'rfind', 'rindex', 'rjust', 'rpartition', 'rsplit', 'rstrip', 'split', 'splitlines', 'startswith', 'strip', 'swapcase', 'title', 'translate', 'upper', 'zfill']
几个字符串常见方法:
name = str('eric')
result = name.__contains__('er') #此方法与in等价
print(result)
print('er' in name) #in和__contains__一致
#
# ###python2.x中方法,3.x中不存在
# name = 'eric{0}'
# name.__format__('alex')
# print(name)
name = 'eric'
result = name.capitalize() #首字母大写
print(result)
result = name.casefold() #所有字符小写
print(result)
result = name.center(20, '*') #居中显示,其余用*号填充
print(result)
result = name.endswith('x', 0, 3) #切片判断以‘x’结尾
print(result)
result = name.startswith('e', 1, 3) #切片判断以‘e’开头
print(result)
name = '理解'
result = name.encode('gbk') #编码为gbk格式,默认是utf-8
print(result)
执行结果:
True
True
Eric
eric
********eric********
False
False
b'xc0xedxbdxe2'
另外一些方法:
name = 'a lex'
result = name.expandtabs() #将TAB转换成空格,默认8个
print(result)
#可以将脚本转化,这样就不会因为空格或者TAB的原因导致脚本不能执行
执行结果:(只有7个空格,不知道为啥?)
a lex
name = 'alex'
result = name.find('ex') #返回找到的位置,没找到就返回-1
result2 = name.find('b')
print(result,result2)
执行结果:
2 -1
name = 'alex'
result = name.index('ex') #返回找到的位置,没找到返回错误
print(result)
result2 = name.index('b')
print(result2)
执行结果:
Traceback (most recent call last)
File "C:/Users/yangfl/PycharmProjects/test/h.py", line 6, in <module>
result2 = name.index('b')
ValueError: substring not found
2
name = 'alex {0} as {1}'
result = name.format('sb', 'eric') #字符串拼接
print(result)
执行结果:
alex sb as eric
name = 'alex {name} as {id}'
result = name.format(name='sb', id='eric') #字符串拼接
print(result)
执行结果:
alex sb as eric
li = ['s', 'b', 'a', 'l', 'e', 'x']
result = '_'.join(li) #将序列连接起来,使用'_'
print(result)
执行结果:
s_b_a_l_e_x
name = 'alex'
result = name.ljust(10, '_') #居左,其余均以"_"填充
result2 = name.rjust(10, '_') #居右,其余均以"_"填充
print(result)
print(result2)
执行结果:
alex______
______alex
name = ' alex '
result = name.rstrip() #删除右边空格
result2 = name.lstrip() #删除左边空格
result3 = name.strip() #删除两边空格
print(result)
print(result2)
print(result3)
执行结果:
alex
alex
alex
# name.lstrip() #删除左空格
# name.rstrip()
# name.maketrans() #有空试下
name = 'alexissb'
result = name.partition('is') #字符串分成三个部分
print(result)
result = name.replace('a', 'o', 1) #替换,第三个参数为替换的个数
print(result)
# name.rfind()
# name.rindex()
# name.rpartition()
result = name.rsplit('i') #这两个没什么区别,不用在意
print(result)
result = name.split('i')
print(result)
3)列表
列表是python中最为灵活的有序集合类型:
- 任意对象的有序集合
- 可以收集其他任意对象,而且按照由左至右的顺序排列
- 通过偏移读取整
- 与字符串类似
- 可变长度,异构以及任意嵌套
- 长度可变
- 能够包含数字,字符串等
- 属于可变序列的分类
- 可在原序列操作删除、索引赋值等
- 对象引用数组
- 在标准的python解释器中,列表就是C数组而不是链接结构。
列表中常用方法:(列表类中的常用成员)
- 切片操作:
li1 = [1, 2, 3, 4]
print(li1[1:2]) #大于等于1,小于2号索引
print(li1[:2]) #小于2号索引
print(li1[1:]) #大于1号索引
print(li1[0:3:2]) #大于等于0,小于3,相隔2
print(li1[:-1]) #-1之前
执行结果:
[2]
[1, 2]
[2, 3, 4]
[1, 3]
[1, 2, 3]
li1 =[11, 11, 22, 33]
li1.append(44)
print(li1)
li1.clear()
print(li1)
li1 = [11, 11, 22, 33]
result = li1.pop(3) #按下标删除
print(result)
li1 = [11,11,22,33]
li1.remove(11) #按值删除,默认删除第一个
print(li1)
li1 = [11,11,22,33]
li1.reverse() #翻转
print(li1)
执行结果:
[11, 11, 22, 33, 44]
[]
33
[11, 22, 33]
[33, 22, 11, 11]
4)元组
tu = (11, 22, 34,)
li = list(tu)
print(tu)
print(li)
#元组中就两个成员需要注意
# tu.count()
# tu.index()
5)字典
#dic = {'k1':'v1','k2':'v2'}
dic = dict(k1='v1', k2='v2')
new_dic = dic.fromkeys(['k1', 'k2'], 'v1000')
print(new_dic)
print(dic['k1'])
print(dic['k2'])
#print(dic['k3']) #报错
print(dic.get('k3'))
print(dic.get('k3', 'alex')) #'k3'不存在的时候使用'alex'
dic = dict(k1='v1', k2='v2')
dic.pop('k1') #指定key
print(dic)
dic = dict(k1='v1', k2='v2')
dic.popitem() #无序的
print(dic)
dic['k3'] = 123
dic.setdefault('k4') #默认值None
print(dic)
dic = dict(k1='v1', k2='v2')
dic.update({'k3':123})
print(dic)
执行结果:
{'k1': 'v1000', 'k2': 'v1000'}
v1
v2
None
alex
{'k2': 'v2'}
{'k1': 'v1'}
{'k4': None, 'k3': 123, 'k1': 'v1'}
{'k2': 'v2', 'k3': 123, 'k1': 'v1'}
举个小例子,将列表中小于66的数字和大于等于66的数字分成两部分,并将他们存放到字典中。
这几个数是:11, 22, 33, 44, 55, 66, 77, 88, 99, 90
li1 = [11, 22, 33, 44, 55, 66, 77, 88, 99, 90, ]
dic = {}
for i in li1:
if i > 66:
if 'k1' in dic.keys():
dic['k1'].append(i) #dic中key存在,value列表后追加i
else:
dic['k1'] = [i, ] #dic中key不存在,新建一个,并将i做成列表赋值给这个key
else:
if 'k2' in dic.keys():
dic['k2'].append(i)
else:
dic['k2'] = [i, ]
print(dic)