阅读本文需要4.66分钟
之后的引导将以例子入手,作为一个程序员,我相信你从例子入手的话会更快的掌握一门语言。
- 条件判断、循环、dict和set
- 函数
- 列表生成式
第一、条件判断、循环、dict和set
1.1 条件判断
#coding:utf-8
age = input('input num:')
if age > 18:
print('age 大于 18')
elif age > 11 and age < 18:
print('age 大于11 并小于18')
else :
print('其他')
如下:
if <条件判断1>:
<执行1>
elif <条件判断2>:
<执行2>
elif <条件判断3>:
<执行3>
else:
<执行4>
其中input()
:
2.x 下 input
读取的内容和输入的一样的。 但在3.x以上 读取的都是字符串,这一点大家要和raw_input()
做区分
1.2 循环
1.2.1 for in
names = ['Mark','Alison']
for name in names:
print(name)
for <元素> in <集合>:
在这里给大家讲一下 range()
,rangek可以生成对应参数的n个整数。如: range(100)
,就会生成0 到 100的整数。因此在遍历list的时候也可以这样:
names = ['Mark','Alison']
for index in range(len(names)):
print(names[index])
1.2.2 while
sum = 0
n = 99
while n > 0:
sum = sum + n
n = n -2
print(sum)
1.3 集合
1.3.1 dict
Python中内置的字典。在其他语言中是 map之类的 (key-value)
>>> names = {'Mark':'18','Alison':'18'}
>>> names
{'Alison': '18', 'Mark': '18'}
>>> names['Mark']
'18'
>>> names['Jordan'] = '88'
>>> names
{'Jordan': '88', 'Alison': '18', 'Mark': '18'}
>>> names.get('Ali','-1') #get方法可指定默认值,若这个key不存在,返回默认值
'-1'
>>> names.pop('Jordan') #Pop出栈
'88'
>>> names
{'Alison': '18', 'Mark': '18'}
dict适用于需要高速查找的地方。
1.3.2 set
一组不包含value的 key集合,并且不能重复。入参是 list
>>> a = set([1,2,3])
>>> a
set([1, 2, 3])
>>> a.add(5)
>>> a
set([1, 2, 3, 5])
>>> a.remove(5)
>>> a
set([1, 2, 3])
切记关于key
的都是不可变的。因为存储的时候,是通过计算key的hash来做的。
第二、函数
2.1 内置函数
>>> abs(1.2) # 求绝对值
1.2
>>> abs(-1)
1
>>> int('1') # 将str的转换为int
1
>>> str(1) # 将int转换为str
'1'
>>> bool(1) # 转换bool值
True
>>> bool('')
False
2.2 定义函数
Python中使用
def
定义函数,并可通过return
来返回值
>>> def myAbs(x):
... if x > 0:
... return x
... else:
... return -x
...
>>>
>>> myAbs(1)
1
>>> myAbs(-1)
1
>>> myAbs(-2)
2
其中 return
表示函数执行的终止,并将结果返回。
需要注意的是 return None
可直接用 return
表示
2.2.1 空函数
def nop():
pass #可作为占位符,表示还没想好写什么
2.2.2 返回多个值
def fun():
return '1','2'
a,b = fun()
这个还是比较方便的。 不用我们再继续封装起来返回,唯一恶心的就是得约定好规则。
其实这返回不是两个值,而是一个tuple,这个得理解下
2.2.3 默认参数
def fun(a,b=2)
print a,b
其中b的默认值是2
def fun(L=[])
L.append('End')
return L
传一个list,并添加 End
再返回。其中要注意的是,python会记住append的元素。意思就是:如果你多次调用 fun() ,会发现 之后的元素都是 End
因此这种传递List的方式如下:
def fun(L=None):
if L is None:
L = []
L.append('End')
return L
2.2.4 可变参数,使用 *
nums = [1,2,3]
def addNum(*n):
sum = 0
for num in n:
sum +=num
return sum
addNum(*nums)
*nums表示把nums这个list的所有元素作为可变参数传进去。这种写法相当有用,而且很常见。
2.2.5 关键字参数 **
表示允许传入0个或者任意个含参数名的参数,这些关键字参数在函数内部自动组装为一个dict.
def person(name, age, **kw):
print('name:', name, 'age:', age, 'other:', kw)
>>> person('Michael', 30)
name: Michael age: 30 other: {}
>>> person('Bob', 35, city='Beijing')
name: Bob age: 35 other: {'city': 'Beijing'}
>>> person('Adam', 45, gender='M', job='Engineer')
name: Adam age: 45 other: {'gender': 'M', 'job': 'Engineer'}
和可变参数类似,也可以先组装出一个dict,然后,把该dict转换为关键字参数传进去:
>>> extra = {'city': 'Beijing', 'job': 'Engineer'}
>>> person('Jack', 24, city=extra['city'], job=extra['job'])
name: Jack age: 24 other: {'city': 'Beijing', 'job': 'Engineer'}
或者
>>> extra = {'city': 'Beijing', 'job': 'Engineer'}
>>> person('Jack', 24, **extra)
name: Jack age: 24 other: {'city': 'Beijing', 'job': 'Engineer'}
2.2.6 命名关键字参数
对于关键字参数,函数的调用者可以传入任意不受限制的关键字参数。至于到底传入了哪些,就需要在函数内部通过kw检查。
仍以person()函数为例,我们希望检查是否有city和job参数:
def person(name, age, **kw):
if 'city' in kw:
# 有city参数
pass
if 'job' in kw:
# 有job参数
pass
print('name:', name, 'age:', age, 'other:', kw)
但是调用者仍可以传入不受限制的关键字参数:
>>> person('Jack', 24, city='Beijing', addr='Chaoyang', zipcode=123456)
如果要限制关键字参数的名字,就可以用命名关键字参数,例如,只接收city和job作为关键字参数。这种方式定义的函数如下:
def person(name, age, *, city, job):
print(name, age, city, job)
和关键字参数kw不同,命名关键字参数需要一个特殊分隔符,后面的参数被视为命名关键字参数。
调用方式如下:
>>> person('Mark', 24, city='hangzhou', job='Engineer')
Mark 24 hangzhou Engineer
第三、列表生成式
List Comprehensions,是Python内置的非常简单却强大的可以用来创建list的生成式
举例:
>>> [x*x for x in range(1,11)]
[1, 4, 9, 16, 25, 36, 49, 64, 81, 100]
>>>
>>>
>>> [m + n for m in 'ABC' for n in 'XYZ']
['AX', 'AY', 'AZ', 'BX', 'BY', 'BZ', 'CX', 'CY', 'CZ']
>>>
>>>
>>> d = {'x': 'A', 'y': 'B', 'z': 'C' }
>>> for k, v in d.items():
... print(k, '=', v)
...
y = B
x = A
z = C
第四、生成器 generator
如名字,其就是一个生成我们所需数据的容器,而不像 列表生成式,计算出所有数据。因此节省了空间,也解决了时间
>>> g = (x * x for x in range(10))
>>> g
<generator object <genexpr> at 0x1022ef630>
遍历: next(g)
>>> g = (x * x for x in range(10))
>>> for n in g:
... print(n)
...
0
1
4
9
16
25
36
49
64
81
yeild
可中断当前操作,使函数成为 生成器 而不是普通函数
举例: 杨慧三角
1
1 1
1 2 1
1 3 3 1
1 4 6 4 1
1 5 10 10 5 1
def yanghu(n):
L=[1]
while 1:
yeild L
L = [L[x] + L[x+1] for x in range(len(L) -1)]
L.insert(0,1)
L.append(1)
if len(L)>n:
break
for n in yanghu(10):
print n
小结
本篇用一些简单的例子来讲解了下基础知识。 多动手练练哦