python FAQ (updating)

 

Python是如何进行内存管理的?

引用计数器

什么是lambda函数?它有什么好处?

匿名函数。简洁

how do I iterate over a sequence in reverse order?

sequence include string , list, tuple. use index 

>>> p[2]
'cd'
>>> p[1]
'bc'
>>> p[0]
'ab'
>>> print p
['ab', 'bc', 'cd']

Python是如何进行类型转换的?

int(x) float(y) 

Python里面如何实现tuple和list的转换?

tuple(ls) list(tp)

请写出一段Python代码实现删除一个list里面的重复元素

sort and then remove

Python如何实现单例模式?其他23种设计模式python如何实现?

?

Python里面如何拷贝一个对象?

介绍一下except的用法和作用?

try:

    sentence

except:

    except handle

finally:

   final handle

except: #捕获所有异常

except: <异常名>: #捕获指定异常

except:<异常名1,异常名2):捕获异常1或者异常2

except:<异常名>,<数据>:捕获指定异常及其附加的数据

except:<异常名1,异常名2>:<数据>:捕获异常名1或者异常名2,及附加的数据库

常用异常名:

异常名    描述
AttributeError 调用不存在的方法引发的异常
EOFError     遇到文件末尾引发的异常
ImportError 导入模块出错引发的异常
IndexError     列表越界引发的异常
IOError     I/O操作引发的异常,如打开文件出错等
KeyError   使用字典中不存在的关键字引发的异常
NameError 使用不存在的变量名引发的异常
TabError 语句块缩进不正确引发的异常
ValueError 搜索列表中不存在的值引发的异常
ZeroDivisionError   除数为零引发的异常

Python中pass语句的作用是什么?

do nothing to create a gramma

介绍一下Python下range()函数的用法?

>>> range(1,10)
[1, 2, 3, 4, 5, 6, 7, 8, 9]
>>> range(1,10,2)
[1, 3, 5, 7, 9]
>>> range(10)
[0, 1, 2, 3, 4, 5, 6, 7, 8, 9]

 

如何用Python来进行查询和替换一个文本字符串?

Python里面search()和match()的区别?

re.search:

Scan through string looking for a match to the pattern, returning
a match object, or None if no match was found.

re.match:

Try to apply the pattern at the start of the string, returning
a match object, or None if no match was found.

用Python匹配HTML tag的时候,<.*>和<.*?>有什么区别?

<.*?>   there is  a element after the "." .

Python里面如何生成随机数?

print random.randint(10,12)

print random.choice(['ab','bc','cd'])

>>> p=['ab','bc','cd']
>>> print p
['ab', 'bc', 'cd']
>>> random.shuffle(p)#disorder them
>>> print p
['ab', 'cd', 'bc']

如何用Python来发送邮件?

ref ref-code

#!/usr/bin/env python
# -*- coding: gbk -*-
#导入smtplib和MIMEText
import smtplib
from email.mime.text import MIMEText
#############
#要发给谁,这里发给2个人
mailto_list=["aaa@juyimeng.com","bbb@juyimeng.com"]
#####################
#设置服务器,用户名、口令以及邮箱的后缀
mail_host="smtp.126.com"
mail_user="xxx"
mail_pass="yyy"
mail_postfix="126.com"
######################
def send_mail(to_list,sub,content):
    '''
    to_list:发给谁
    sub:主题
    content:内容
    send_mail("aaa@126.com","sub","content")
    '''
    me=mail_user+"<"+mail_user+"@"+mail_postfix+">"
    msg = MIMEText(content)
    msg['Subject'] = sub
    msg['From'] = me
    msg['To'] = ";".join(to_list)
    try:
        s = smtplib.SMTP()
        s.connect(mail_host)
        s.login(mail_user,mail_pass)
        s.sendmail(me, to_list, msg.as_string())
        s.close()
        return True
    except Exception, e:
        print str(e)
        return False
if __name__ == '__main__':
    if send_mail(mailto_list,"subject","content"):
        print "发送成功"
    else:
        print "发送失败"

 

有两个序列a,b,大小都为n,序列元素的值任意整形数,无序;
要求:通过交换a,b中的元素,使[序列a元素的和]与[序列b元素的和]之间的差最小。
1. 将两序列合并为一个序列,并排序,为序列Source
2. 拿出最大元素Big,次大的元素Small
3. 在余下的序列S[:-2]进行平分,得到序列max,min
4. 将Small加到max序列,将Big加大min序列,重新计算新序列和,和大的为max,小的为min。

Python如何定义一个函数?

def func():

有没有一个工具可以帮助查找python的bug和进行静态的代码分析?

pylint

如何在一个function里面设置一个全局的变量?

 global val

CONSTANT = 0

def modifyConstant() :
        global CONSTANT
        print CONSTANT
        CONSTANT += 1
        return

if __name__ == ‘__main__’ :
        modifyConstant()
        print CONSTANT

 

 

一、文化
----

1,听过 the zen of python 吗?尽可能地默写它,中英文皆可,大意也可。如果没有听过,谈谈你对 pythonic 的看法,或者你认为什么样的 python 代码才是好代码。

二、数据结构与算法
---------

2,现在有一个 dict 对象 adict,里面包含了一百万个元素,查找其中的某个元素的平均需要多少次比较?一千万个元素呢?

3,现在有一个 list 对象 alist,里面的所有元素都是字符串,编写一个函数对它实现一个大小写无关的排序。

4,python 里关于“堆”这种数据结构的模块是哪个?“堆”有什么优点和缺点?举一个游戏开发中可能会用到堆的问题(不限是于 python 的堆,可以是其它语言的相关实现)。

5,set 是在哪个版本成为 build-in types 的?举一个你在以往项目中用到这种数据结构的问题(不限是于 python 的 set ,可以是其它语言的相关实现),并说明为什么当时选择了 set 这种数据结构。

6,有一个排好序地 list 对象 alist,查找其中是否有某元素 a(尽可能地使用标准库函数)。

三、库应用
-----

7,说说 dict 的 items() 方法与 iteritems() 方法的不同。

8,写一段程序逐行读入一个文本文件,并在屏幕上打印出来。

9,默写尽可能多的 str 对象的方法。

10,打乱一个排好序的 list 对象 alist。

11,有二维的 list 对象(即它的每一个元素都是一个 list 对象)alist,假定其中的所有元素都具有相同的长度(把 alist 想象成一个表格),写一段程序根据元素的第二个元素排序(即对表格的第二列字段排序)。

四、设计
----

12,实现一个 stack。

13,编写一个简单的 ini 文件解释器。

14,现有 N 个纯文本格式的英文文件,实现一种检索方案,即做一个小搜索引擎。 

 

posted @ 2013-02-18 16:27  邓维  阅读(557)  评论(0编辑  收藏  举报