Python注释

Python的注释以#开头,后面的文字直到行尾都算注释

Python基本数据类型

整数、浮点数(浮点数也就是小数,之所以称为浮点数,是因为按照科学记数法表示时,一个浮点数的小数点位置是可变的)、字符串(字符串是以''""括起来的任意文本)、布尔值、

空值(空值是Python里一个特殊的值,用None表示)

print语句

print语句也可以跟上多个字符串,用逗号“,”隔开,就可以连成一串输出,遇到逗号“,”会输出一个空格;使用“+”拼接不会产生空格

print 'The quick brown fox', 'jumps over', 'the lazy dog'

print("I'm Python. Nice to meet you!") # Python 3.x的语句方式

Python之字符串

字符串通过 " 或 ' 括起来,用\对字符串中的特殊字符进行转义;且字符串是不可变的;

其它值转换为字符串机制:repr函数和str函数;

多行字符串,可以用'''...'''表示:

    '''Line 1
    Line 2
    Line 3'''

在字符串前面加个前缀 r ,表示这是一个raw字符串,表示里面的字符不需要转义。

在多行字符串前面添加 r ,把这个多行字符串也变成一个raw字符串;

  r'...'表示包含'"的字符串时需注意匹配:

print r'Python is created by "Guido". Let's start learn Python in imooc!' # r'...' --里面r 的第一个 ' 和 Let' 的 ' 匹配了

print r'Python is created by "Guido".’ #不会报错

r'...'不能再结尾处输入反斜线“\”

    Unicode字符串:因为计算机只能处理数字,如果要处理文本,就必须先把文本转换为数字才能处理(字节编码表)。而早期的的Python只支持ASCII编码,Python在后来添加了对Unicode的支持,以Unicode表示的字符串用u'...'表示,比如:print u'中文';

Python 3.x直接对Unicode进行支持,所有的字符串都是unicode字符串;

Unicode字符串除了多了一个 u 之外,与普通字符串没啥区别,转义字符、raw字符串和多行表示法仍然有效;

    raw+多行:

 ur'''Python的Unicode字符串支持"中文",
"日文",
"韩文"等多种语言'''
如果中文字符串在Python环境下遇到 UnicodeDecodeError,这是因为.py文件保存的格式有问题。可以在第一行添加注释 # -*- coding: utf-8 -*-;

目的是告诉Python解释器,用UTF-8编码读取源代码。注意点:当第一行添加了注释后,不能再在语法中使用 u,否则会报错;

   字符串格式化:老式的格式化语法 %:可以用来格式化字符串,用指定的参数替代 %s,如程序需在Python2.5以下环境运行才建议使用;

转换说明符:%s   %.3f

模板字符串:string模块的Template() 和 substitute()方法

推荐使用方法 format 方法来格式化字符串

Python中布尔类型

布尔类型运算: 与运算(and:只有两个布尔值都为 True 时,计算结果才为 True。

或运算(or):只要有一个布尔值为 True,计算结果就是 True。

非运算(not:把True变为False,或者把False变为True。

布尔类型还可以与其他数据类型做 and、or和not运算,Python把0空字符串''None看成 False,其他数值和非空字符串都看成True;注:只是看成,没有进行转换

a = True
        print a and 'a=T' or 'a=F' #=> a=T

    and or 运算的一条重要法则:短路计算

  1. 在计算 a and b 时,如果 a 是 False,则根据与运算法则,整个结果必定为 False,因此返回 a;如果 a 是 True,则整个计算结果必定取决与 b,因此返回 b的值。
  2. 在计算 a or b 时,如果 a 是 True,则根据或运算法则,整个计算结果必定为 True,因此返回 a;如果 a 是 False,则整个计算结果必定取决于 b,因此返回 b的值。

Python变量

变量是用一个变量名表示,变量名必须是大小写英文、数字和下划线(_)的组合,且不能用数字开头;

在Python中,等号=是赋值语句,可以把任意数据类型赋值给变量,同一个变量可以反复赋值,而且可以是不同类型的变量;这种变量本身类型不固定的语言称之为动态语言;

   示例  a = 123     # a是整数    
        a = 'imooc'   # a变为字符

Python数据结构

序列(sequence):最基本的数据结构,每个元素被自动分配一个序号(索引);内建序列数据结构(列表、元组、字符串、Unicode字符串、buffer对象和xrange对象);

映射(mapping):通过名称来引用值得数据结构;内建数据结构(字典dict);

集合(set):

堆(heap):是优先队列的一种,Python没有独立的堆类型,只有一个包含一些堆操作函数的模块headq(q是queue的缩写);

双端队列(deque):在需要按照元素增加的顺序来移除元素时非常有用。Python 2.4及以上新增在collections模块中;

Python列表:list

list是一种有序的集合(元素是按照顺序排列),可以随时添加和删除其中的元素。

直接用 [ ] 把list的所有元素都括起来,就是一个list对象。
由于Python是动态语言,所以list中包含的元素并不要求都必须是同一种数据类型,我们完全可以在list中包含各种数据:L = ['Michael', 100, True]
通过索引来获取list中的指定元素。如:L[0]
倒序索引: 我们可以用 -1 这个索引来表示最后一个元素:L[-1]

添加新的元素: 第一个办法是用 list 的 append() 方法,把新同学追加到 list 的末尾;

第二个方法是用list的 insert()方法,它接受两个参数,第一个参数是索引号,第二个参数是待添加的新元素;原来索引号及后面的值都自动向后移动一位。

删除元素:1. del语句--- del L[index]

                    2. pop()方法删掉list的最后一个元素,pop(index)方法删掉list中指定索引的元素,并且它还返回这个元素;

3.remove方法,移除列表中某个值的第一个匹配项,修改了列表无返回值

对list中的某一个索引赋值,就可以直接用新的元素替换掉原来的元素,list包含的元素个数保持不变。

生成表达式(conprehension expression):把要生成的元素语法放到前面,后面跟for循环(变量的取值),就可以把序列/集合创建出来;

[x * x for x in range(1, 11)]   #=>[1, 4, 9, 16, 25, 36, 49, 64, 81, 100]

生成表达式的 for 循环后面还可以加上 if 判断,只有 if 判断为 True 的时候,才把循环的当前元素添加到列表中。

[x * x for x in range(1, 11) if x % 2 == 0] #=>[4, 16, 36, 64, 100]

可以用多层 for 循环来生成列表

[m + n for m in 'ABC' for n in '123'] #=>['A1', 'A2', 'A3', 'B1', 'B2', 'B3', 'C1', 'C2', 'C3']

L = []

for m in 'ABC':

for n in '123':

L.append(m + n)

M = [[1, 2, 3],          # A 3X3 matrix, as nested lists
                                   [4, 5, 6],          # Code can span lines if bracketed
                                       [7, 8, 9]]

G={sum(row) for row in M}

G={i:sum(M[i]) for i in range(3)}

Python元组:tuple

tuple是另一种有序的列表。tuple和list非常类似,但是,tuple一旦创建完毕,就不能修改。tuple没有 append()方法,也没有insert()和pop()方法。

创建tuple和创建list唯一不同之处是用( )替代了[ ]

定义单元素的tuple: 单元素tuple要多加一个逗号“,”,避免歧义; //t = (1,) 
在打印单元素tuple时,也自动添加了一个“,”,为了更明确地告诉你这是一个tuple。 //print t  #=>(1,)
多元素 tuple 加不加这个额外的“,”效果是一样的:
t = (1, 2, 3,)
print t #=>(1, 2, 3)

tuple所谓的不变是指“指向不变”,tuple的每个元素,指向永远不变。即指向'a',就不能改成指向'b',指向一个list,就不能改成指向其他对象,但指向的这个list本身是可变的;

Python序列通用操作

切片(Slice)操作符:简化取指定索引范围的操作;语法  L[fromIndex : toIndex]

L[0:3]表示,从索引0开始取,直到索引3为止,但不包括索引3(可以看做数学之中左闭右开区间);<=> L[:3] 从零开始的索引可省略不写;

L[1:] :省略末尾,从1开始直到结束;

L[:]表示复制出了一个新list;

L[fromIndex : toIndex : N]:切片操作可以指定第三个参数,第三个参数表示每N个取一个 ,L[::2] 每两个元素取出一个;N不能为0;

步进为正,必须让开始索引小于结束索引;步进为负,必须让开始索引大于结束索引;------否则获取的是空列表;

支持倒序切片;如果使用倒序切片时,需要获取结束索引的值,只能通过省略末尾来获取;

list换成tuple,切片操作完全相同,只是切片的结果也变成了tuple。同样也适用于字符串(字符串可以被视为字符的列表),操作结果仍是字符串;

序列相加:使用加运算符可以进行序列的连接操作生成一个新的序列,并不会改变原始序列;注只有相同类型的序列才可以进行连接操作;

分片赋值:不能用于不可变的序列(元组,字符串,Unicode字符串)
                    #不等长序列替换
                    name=list('Perl')
                    name[1:]=list('ython')
                    numbers=[1,5]
                    #插入元素
                    numbers[1:1]=[2,3,4]
                    #删除元素
                    numbers[2:4]=[]

序列乘法:用数字N乘以一个序列会生成一个新的序列,新的序列中,原来的序列将被重复N次;

temp=[1,2]*4 #=>[1, 2, 1, 2, 1, 2, 1, 2]
                     temp=(2,3)*4 #=>(2,3,2,3,2,3,2,3)

成员资格:用 in 来返回元素是否在序列中;

长度 最大值 最小值 :len(L) max(L) min(L)

Python字典:dict

花括号 {} 表示这是一个dict,然后按照 key: value, 写元素。最后一个 key: value 的逗号可以省略。使用 d[key] 的形式来查找对应的 value;

filled_dict = {"one": 1, "two": 2, "three": 3}

判断key是否存在:用 in 操作符;    'Paul' in filled_dict  #=> false

使用dict本身提供的一个get 方法,在Key不存在的时候,返回None;

get 方法支持在不存在的时候返回一个默认值 ;   filled_dict.get("four", 4)  # => 4

dict的第一个特点是查找速度快,无论dict有10个元素还是10万个元素,查找速度都一样。而list的查找速度随着元素增加而逐渐下降。缺点是占用内存大,还会浪费很多内容;

dict的第二个特点就是存储的key-value序对是没有顺序的;key不能重复。不能用dict存储有序的集合。

dict的第三个特点是作为 key 的元素必须不可变,Python的基本类型如字符串、整数、浮点数都是不可变的,都可以作为 key。但是list是可变的,不能作为 key。

用赋值语句可以往dict中添加新的 key-value或当 key 已经存在时直接更新value ;     filled_dict["four"]=4

values() 方法实际上把一个 dict 转换成了包含 value 的list。 itervalues() 方法不会转换;

items() 方法把dict对象转换成了包含tuple的list;items() 也有一个对应的 iteritems(),iteritems() 不把dict转换成list;

setdefault 是一个更安全的添加字典元素的方法:
        filled_dict.setdefault("five", 5)  # filled_dict["five"] 的值为 5
        filled_dict.setdefault("five", 6)  # filled_dict["five"] 的值仍然是 5

Python集合:set

创建 set 的方式是调用 set() 并传入一个 list,list的元素将作为set的元素:

some_set = set(); #空列表

some_set = set([1, 2, 2, 3, 4])  # some_set 现在是 set([1, 2, 3, 4])

set内部存储的元素是无序的。set不能包含重复的元素,会自动去掉重复的元素;

Python 2.7 之后,大括号可以用来表示集合 : filled_set = {1, 2, 2, 3, 4}  # => {1 2 3 4}

用in操作符判断一个元素是否在set中;10 in filled_set  # => False

添加元素,用set的add()方法:如果添加的元素已经存在于set中,add()不会报错;

删除set中的元素,用set的remove()方法,如果元素不存在set中,remove()会报错;

Python之条件判断

if 语句后接表达式,然后用:表示代码块开始。

if ... else ... 语句,else 后面有个“:”

if ... 多个elif ... else ... 的结构,一次写完所有的规则;

if 语句可以作为表达式来使用
         "yahoo!" if 3 > 2 else 2  # => "yahoo!"

Python之循环

for 循环就可以依次把list或tuple的每个元素迭代出来:

L = ['Adam', 'Lisa', 'Bart']
for name in L:
    print name
在Python中,迭代是通过 for ... in 来完成的,迭代操作就是对于一个集合,无论该集合是有序还是无序,我们用 for 循环总是可以依次取出集合的每一个元素。

while 循环,while 循环不会迭代 list 或 tuple 的元素,而是根据表达式判断循环是否结束。

N = 10
x = 0
while x < N:
    print x
    x = x + 1

    break语句:退出循环

    continue:跳过后续循环代码,继续下一次循环。

    pass: 什么也不做,相当于C#中的空语句“{ }”。

Python之函数

定义一个函数要使用 def 语句,依次写出函数名、括号、括号中的参数和冒号:,在缩进块中编写函数体,函数的返回值用 return 语句返回。return None可以简写为return。

调用一个函数,需要知道函数名称参数,如果传入的参数数量不对,会报TypeError的错误;

如果传入的参数数量是对的,但参数类型不能被函数所接受,也会报TypeError的错误,并且给出错误信息;

    函数返回多值:其实就是返回一个tuple在语法上,返回一个tuple可以省略括号;

import math

def move(x, y, step, angle):

nx = x + step * math.cos(angle)

ny = y - step * math.sin(angle)

return nx, ny

r = move(100, 100, 60, math.pi / 6)

函数的默认参数的作用是简化调用,只需要把必须的参数传进去。在需要的时候,传入额外的参数来覆盖默认参数值。默认参数只能定义在必需参数的后面;

定义可变参数:让一个函数能接受任意个参数,可变参数的名字前面有个 号,我们可以传入0个、1个或多个参数给可变参数(这些参数是按照顺序排列);

Python解释器会把传入的一组参数组装成一个tuple传递给可变参数;

def varargs(*args):
     if args:
         return args
     else:
         return 0.0
     varargs(1, 2, 3)  # => (1,2,3)

参数的分拆:当你要传递的参数已经是一个列表,但调用的函数却接受分开一个个的参数值
     #使用* 操作符来自动把参数列表拆开:
     args=[3,6]
     x=list(range(*args)) # *args 将列表 args 拆分成3,6 两个参数
     print x
     #使用 ** 操作符自动进行参数字典的分拆:
     def parrot(voltage,state='a stiff',action='voom'):
         print "-- This parrot wouldn't ",action,
         print "if you put ",voltage,"volts through it.",
         print "E's",state,"!"    
     d={"voltage":"four million", "state":"bleedin demised","action":"voom"}
     parrot(**d)
     def keyword_args(**kwargs):
         return kwargs
     # 实际效果:
     keyword_args(big="foot", loch="ness")  # => {"big": "foot", "loch": "ness"}

关键字lambda表示匿名函数,冒号前面的x表示函数参数。
     限制:只能有一个表达式,不写return,返回值就是该表达式的结果。
     (lambda x: x > 2)(3)  # => True

     enumerate() 函数自动把每个元素变成 (index, element) 这样的tuple

L = ['Adam', 'Lisa', 'Bart', 'Paul']
     enumerate(L) #=>[(0, 'Adam'), (1, 'Lisa'), (2, 'Bart'), (3, 'Paul')]

内置高阶函数

#map接收一个函数f和一个list,并通过把函数f依次作用在list的每个元素上,得到一个新的list并返回
     map(add_10, [1, 2, 3])  # => [11, 12, 13]
     #reduce()函数接收一个函数f一个list,传入的函数f必须接收两个参数,reduce()对list的每个元素反复调用函数f,并返回最终结果值
     def f(x, y):
         return x + y
     reduce(f, [1, 3, 5, 7, 9]) # =>25  f(1, 3) -> f(f(1,3),5) >>>>
     #reduce()还可以接收第3个可选参数,作为计算的初始值
     reduce(f, [1, 3, 5, 7, 9], 100) #=>125
     #接收一个函数 f 和一个list,这个函数 f 的作用是对每个元素进行判断,返回 True或 False,filter()根据判断结果自动过滤掉不符合条件的元素,返回由符合条件元素组成的新list
     filter(lambda x: x > 5, [3, 4, 5, 6, 7])  # => [6, 7]

Python之装饰器decorator

Python - Learn Note (2)的更多相关文章

  1. Python - Learn Note (3)

    Python之模块 包就是文件夹:包可以有多级: 模块就是 xxx.py文件:可以创建自己的模块,并且导入它们,模块的名字就和文件的名字相同: Python使用import语句导入一个模块. impo ...

  2. Python - learn note(1)

    1. 下载安装Python 2.7(为了向下兼容以前的版本), Python 3.5(VS2015不支持配置3.6的环境) 教程 需要使用VS2015进行开发,必须勾选上后面两项: 2. VS2015 ...

  3. #MySQL for Python(MySQLdb) Note

    #MySQL for Python(MySQLdb) Note #切记不要在python中创建表,只做增删改查即可. #步骤:(0)引用库 -->(1)创建连接 -->(2)创建游标 -- ...

  4. Python Function Note

    Python Function Note #汉诺塔问题Python实现 def my_move(n, a, b, c): if n == 1: print(a + ' --> ' + c) el ...

  5. Php learn note

    Php learn note 1. Between two part of ECHO, there is , sign rather than + sign. echo 'Hello World!!' ...

  6. python learn note1

    1.python 的缩进 习惯了java,c++之类的宽容,初学python,被它摆了道下马威,写if else,竟然必须要我正确用缩进格式,原来在python里不能用括号来表示语句块,也不能用开始/ ...

  7. Python Study Note 1

    Learn The First Day OF Operation Notes

  8. How do I learn machine learning?

    https://www.quora.com/How-do-I-learn-machine-learning-1?redirected_qid=6578644   How Can I Learn X? ...

  9. Python 的经典入门书籍

    实python非常适合初学者入门,上手很容易.我就是完全通过网上资源学了python的.最大的是3点经验:1.找一本浅显易懂,例程比较好的教程,从头到尾看下去.不要看很多本,专注于一本.把里面的例程都 ...

随机推荐

  1. UVA 624 ---CD 01背包路径输出

    DescriptionCD You have a long drive by car ahead. You have a tape recorder, but unfortunately your b ...

  2. ERROR 2002 (HY000): Can't connect to local MySQL server through socket

    原文链接:https://blog.csdn.net/u011262253/article/details/82802157 一.错误现场还原: 下面我们通过三种方式来连接,然后观察提示的错误信息: ...

  3. centos 特殊权限 各种搜索命令 lsattr ,chattr,suid,sgid,sbit,file,type是否是内置命令,stat文件属性 ,whereis,locate,find,ln 内部命令和外部命令 第五节课

    centos 特殊权限 各种搜索命令 lsattr ,chattr,suid,sgid,sbit,file,type是否是内置命令,stat文件属性 ,whereis,locate,find,ln   ...

  4. ScyllaDB - 基础部署

    基础环境 操作系统: CentOS 7.2: 集群节点(虚拟机):172.16.134.15 ~ 17: 基础准备 安装依赖和卸载 abrt ( abrt 和 coredump 配置冲突 ): sud ...

  5. 认识与设计Serverless(二)

    一.设计Serverless的功能模块 第一节讲了Serverless一些概念与特性,废话居多,概念的东西了解过后要有设计与构思,才能学到精髓,一个Serverless平台的形成,涉及到很多模块的架构 ...

  6. 多口USB HUB信号延长器 USBX-M200(针对于A客户使用时很棒吧)

    大家都知道A客户是不允许在设备里面出现无线的东东,但是USB的传输距离有很短.咋办呢?? 见下图 http://rextron-cn.com/product_show.asp?id=74

  7. 15信号sigaction

    信号处理 信号值小于 SIGRTMIN 的信号 (1~31) 都是不可靠信号 某些unix版本中,调用信号函数处理后会自动恢复默认信号处理,所以在信号处理函数中还需要继续调用signal函数设置信号处 ...

  8. SQL: 为列取有意义的名称

    1.用法 2.在where字句中使用别名要注意,(别名是select之后才会生效)

  9. Flume同时输出数据到HDFS和kafka

    cd /usr/local/flume/conf vim flume-exec-total.conf ## Explain #通过sink把数据分别输出到kafka和HDFS上 # Name the ...

  10. 根据源Excel文件,新建Excel文件

    /** * 描述:根据源Excel文件,创建新的Excel文件 * @param excelFile * @throws CheckException */public static void cre ...