[后端Day1]Python2.7之基础

注:以下内容全部为 廖雪峰的官方网站 中学习内容的摘要和总结

输入和输出:

name = raw_input('please enter your name: ')
 print '100 + 200 =', 100 + 200

数据类型和变量:

变量本身类型不固定的语言称之为动态语言,Python是动态语言。

 

字符串和编码:

1.ASCII(不全)、Unicode(全,但定长所以占用空间大)和UTF-8(全,变长) 。

2.普通的字符串'ABC'在Python内部都是ASCII编码,Python后来添加了对Unicode的支持,以Unicode表示的字符串用u'...'表示。

print u'中文'

3.由于Python源代码也是一个文本文件,所以,当源代码中含中文时,保存源代码时,需指定保存为UTF-8编码。当Python解释器读取源代码时,为了让它按UTF-8编码读取,我们通常在文件开头写上这两行:

#!/usr/bin/env python
# -*- coding: utf-8 -*-

第一行注释是为了告诉Linux/OS X系统,这是一个Python可执行程序,Windows系统会忽略这个注释;

第二行注释是为了告诉Python解释器,按照UTF-8编码读取源代码,否则,你在源代码中写的中文输出可能会有乱码。

(申明了UTF-8编码并不意味着你的.py文件就是UTF-8编码的)必须要确保Notepad++正在使用UTF-8 without BOM编码,在encoding目录下选择该项。

4.关于格式化,采用如下占位符及形式:

 'Hi, %s, you have $%d.' % ('Michael', 1000000)

使用list和tuple: 

列表数据类型:list。list是一种有序的集合,可以随时添加和删除其中的元素。

>>> classmates = ['Michael', 'Bob', 'Tracy']
>>> classmates
['Michael', 'Bob', 'Tracy']

list其他操作见廖雪峰官网。

另一种有序列表叫元组:tuple。tuple和list非常类似,但是tuple一旦初始化就不能修改,

>>> t = (1, 2)
>>> t
(1, 2)

只有1个元素的tuple定义时必须加一个逗号,,来消除歧义:

>>> t = (1,)
>>> t
(1,)

综上,list和tuple是Python内置的有序集合,一个可变,一个不可变。根据需要来选择使用它们,尽量使用tuple,更安全。

条件判断和循环:

条件判断:

age = 3
if age >= 18:
    print 'your age is', age
    print 'adult'
else:
    print 'your age is', age
    print 'teenager'
age = 3
if age >= 18:
    print 'adult'
elif age >= 6:
    print 'teenager'
else:
    print 'kid'

for...in循环:

依次把list或tuple中的每个元素迭代出来。

for x in ...循环就是把每个元素代入变量x,然后执行缩进块的语句。

sum = 0
for x in [1, 2, 3, 4, 5, 6, 7, 8, 9, 10]:
    sum = sum + x
print sum

range(101)就可以生成0-100的整数序列

sum = 0
for x in range(101):
    sum = sum + x
print sum

while循环:

sum = 0
n = 99
while n > 0:
    sum = sum + n
    n = n - 2
print sum

再议raw_input():

此输入自动设为字符串类型,若输入数字且需比较时,需先强制转换成int型等。

birth = int(raw_input('birth: '))

 使用dict和set:

dict:

Python内置了字典:dict的支持,dict全称dictionary,在其他语言中也称为map,使用键-值(key-value)存储,具有极快的查找速度。

>>> d = {'Michael': 95, 'Bob': 75, 'Tracy': 85}
>>> d['Michael']
95

把数据放入dict的方法,除了初始化时指定外,还可以通过key放入:

>>> d['Adam'] = 67
>>> d['Adam']
67

和list比较,dict有以下特点:

  1. 查找和插入的速度极快,不会随着key的增加而增加;
  2. 需要占用大量的内存。

dict可以用在需要高速查找的地方,dict的key必须是不可变对象。这是因为dict根据key来计算value的存储位置,如果每次计算相同的key得出的结果不同,那dict内部就完全混乱了。这个通过key计算位置的算法称为哈希算法(Hash)。

set:

set和dict类似,也是一组key的集合,但不存储value。由于key不能重复,所以,在set中,没有重复的key。

要创建一个set,需要提供一个list作为输入集合:

>>> s = set([1, 2, 3])
>>> s
set([1, 2, 3])

set和dict的唯一区别仅在于没有存储对应的value(都无序),et同样不可以放入可变对象,因为无法判断两个可变对象是否相等。

再议不变对象:

对于不变对象来说,调用对象自身的任意方法,也不会改变该对象自身的内容。相反,这些方法会创建新的对象并返回,这样,就保证了不可变对象本身永远是不可变的。

上一篇:MySQL 调优基础(一) CPU与进程


下一篇:iscc2016 pwn部分writeup