文章目录
- 第3题: 如何用Python删除一个文件?
- 第4题: is 和 == 的区别?
- 第5题:a=1, b=2, 不用中间变量交换a和b的值?
- 第6题:说说你对zen of python的理解,你有什么办法看到它?
第1题:Python里面如何实现tuple和list的转换?
函数tuple(seq)
可以把所有可迭代的(iterable)序列
转换成一个tuple
, 元素不变,排序也不变
list转为tuple:
temp_list = [1,2,3,4,5]
将temp_list进行强制转换:tuple(temp_list)
确定是否转换成功:print(type(temp_list))
函数list(seq)
可以把所有的序列和可迭代的对象
转换成一个list,元素不变,排序也不变
tuple 转为list:
temp_tuple = (1,2,3,4,5)
方法类似,也是进行强制转换即可:list(temp_tuple)
确定是否转换成功:print(type(temp_tuple))
第2题:Python里面search()和match()的区别?
它们两个都在re模块
中
-
match()
函数是在string的开始位置匹配,如果不匹配,则返回None; -
search()
会扫描整个string查找匹配;
match()
>>> import re
>>> print(re.match('hello','helloworld').span()) # 开头匹配到
(0, 5)
>>> print(re.match('hello','nicehelloworld').span()) # 开头没有匹配到
Traceback (most recent call last):
File "<pyshell#2>", line 1, in <module>
print(re.match('hello','nicehelloworld').span())
AttributeError: 'NoneType' object has no attribute 'span'
>>>
search()
>>> print(re.search('a','abc'))
<_sre.SRE_Match object; span=(0, 1), match='a'>
>>> print(re.search('a','bac').span())
(1, 2)
>>>
结论:match() 使用限制更多
第3题: 如何用Python删除一个文件?
os模块的使用
os.remove(path)
删除文件 path,删除时候如果path是一个目录, 抛出 OSError错误。如果要删除目录,请使用rmdir()。
remove() 同 unlink() 的功能是一样的
os.remove('a.txt')
os.removedirs(path)
递归地删除目录。类似于rmdir()
, 如果子目录被成功删除, removedirs()
将会删除父目录;但子目录没有成功删除,将抛出错误。
例如, os.removedirs(“a/b/c”)
将首先删除c
目录,然后再删除b
和a
, 如果他们是空的话,则子目录不能成功删除,将抛出 OSError异常
os.rmdir(path)
删除目录 path,要求path必须是个空目录
,否则抛出OSError错误
第4题: is 和 == 的区别?
hon中对象包含的三个基本要素,分别是:
id(身份标识)
、type(数据类型)
和value(值)
id 身份标识,就是在内存中的地址
完整的举例
>>> a = 'hello'
>>> b = 'hello'
>>> print(a is b)
True
>>> print(a==b)
True
>>> a = 'hello world'
>>> b = 'hello world'
>>> print(a is b)
False
>>> print(a == b)
True
>>> a = [1,2,3]
>>> b = [1,2,3]
>>> print(a is b)
False
>>> print(a == b)
True
>>> a = [1,2,3]
>>> b = a
>>> print(a is b)
True
>>> print(a == b)
True
>>>
-
==
是python标准操作符中的比较操作符
,用来比较判断两个对象的value(值)
是否相等 -
is
也被叫做同一性运算符(对象标示符),这个运算符比较判断的是对象间的唯一身份标识
,也就是id
(内存中的地址)是否相同
我们在检查 a is b 的时候,其实相当于检查 id(a) == id(b)
。而检查a == b
的时候,实际是调用了对象 a 的 __eq()__
方法,a == b
相当于 a.__eq__(b)
。
这里还有一个问题,为什么 a 和 b 都是 “hello” 的时候,a is b 返回True,而 a 和 b都是 “hello world” 的时候,a is b 返回False呢?
这是因为前一种情况下Python的字符串驻留机制
起了作用。对于较小的字符串,为了提高系统性能Python会保留其值的一个副本,当创建新的字符串的时候直接指向该副本即可。
所以 “hello” 在内存中只有一个副本,a 和 b 的 id 值相同,而 “hello world” 是长字符串,不驻留内存,Python中各自创建了对象来表示 a 和 b,所以他们的值相同但 id 值不同。
试一下当a=247
,b=247
时它们的id还是否会相等。事实上Python 为了优化速度,使用了小整数对象池,避免为整数频繁申请和销毁内存空间。而Python 对小整数的定义是 [-5, 257),只有数字在-5到256之间它们的id才会相等,超过了这个范围就不行了。
>>> a = 247
>>> b = 247
>>> print(a is b)
True
>>> a = 258
>>> b = 258
>>> print(a is b)
False
>>>
is 是检查两个对象是否指向同一块内存空间,而
==
是检查他们的值是否相等。is比==
更加严格
第5题:a=1, b=2, 不用中间变量交换a和b的值?
方法一
>>> a = 5
>>> b = 6
>>> a = a+b
>>> b = a-b
>>> a = a-b
方法二
>>> a = a^b
>>> b = b^a
>>> a = a^b
方法三
a,b = b,a
第6题:说说你对zen of python的理解,你有什么办法看到它?