Python 笔记(测试)

Pyton 学习笔记[5]

一,语句的结束

  • 每一句逻辑行的结束都是以物理行的结束为结束。如果逻辑行想链接两行物理行,请使用“\”,但值得注意的是,他只能用来链接代码而不是能链接两行注释或字符串,如:
    if 1900 < year < 2100 and 1 <= month <= 12 \
       and 1 <= day <= 31 and 0 <= hour < 24 \
       and 0 <= minute < 60 and 0 <= second < 60:   # Looks like a valid date
    return 1
    	
  • 但是括号内的内容,不需要使用反斜杠也可以链接多行,如:
    month_names = ['Januari', 'Februari', 'Maart',      # These are the
                   'April',   'Mei',      'Juni',       # Dutch names
                   'Juli',    'Augustus', 'September',  # for the months
                   'Oktober', 'November', 'December']   # of the year
    	

二,如何定义一个函数或者方法

use "def" to definition fuction

三,一个*号和两个的区别

2*3 表示2乘以3   2**3表示2的立方

四,缩进——代码格式

java通过括号来界定一段代码,而python使用缩进做为代码段的界定。空格和tabs都可以用来作为缩进,但最好不要混用。如:

def perm(l):
        # Compute the list of all permutations of l
    if len(l) <= 1:
                  return [l]
    r = []
    for i in range(len(l)):
             s = l[:i] + l[i+1:]
             p = perm(s)
             for x in p:
              r.append(l[i:i+1] + x)
    return r

五,字符串连接

用引号扩起来的两个相邻字符串,实际意义表示为他们两相连的那个字符串。且这两个字符串的引号可以不同,例如:

"hello" 'world' is equivalent to "helloworld".

六,数据结构

在python中所有数据类型都是对象,比如int、和string。这同java不一样,java中int是原始本地类型(primitive native types)

6.1 list和tuble的区别

  • list是用方括号括起来的,成员之间通过逗号分割的表示方式。tuble是用小括号(小括号可选)扩起来,成员直接用逗号分割。
  • list是可变的,可以进行增删改,tuble如其名一样,作为元组他们是不变的

6.2 dictionary

dictionary有点类似java中的map。dictionary的key必须是唯一且不可修改的值,比如string,但其映射的value可以是可变的值,如list,解读的意思,就是key值必须取基本类型,比如int和string,因为基本类型都是不可变的。dictionary的格式有点像json

6.3 sequence

6.3.1 定义

sequence特指那些具有顺序的数据类型,所以前面介绍的list、tuple、string都属于sequence类型

6.3.2 用法

6.3.2.1 索引取值

使用方括号加数字表示取sequence的具体某位置的值,如:[2]

6.3.2.2 子sequence截取

使用方括号加冒号的方式表示取子sequence,冒号是必须的,两边的数字可选,取值方式为左开右闭,如:[2:3]

值得说明的是,截取的子sequence是一个完全新的对象,所以如果不指定数字,而直接使用[:]来截取,相当于对原sequence复制了一份新的对象

使用两个冒号时,第三个数字指定截取时的步长,如:[2:3:1]

6.4 Set

无序的对象集合,原理和操作方式同java类似

6.5 References

声明一个变量,并给他赋值。实际上是把对象的引用赋给了这个变量。多一个变量可以指向同一个对象。引用的概念同java类似

七,编程方式

7.1 面向过程编程

python支持面向过程编程风格,就像c一样,定义方法,定义变量。程序的组织方式是通过过程块来组织

7.2 面向对象编程

python同时也支持面向对象编程风格,就像java一样。类来组织程序块,类中可以定义函数,变量,类中的函数叫做方法。类中的变量和方法统称为类的属性

属于每一个实例的变量叫做实例变量

只属于类的变量叫做类变量

7.2.1 self

类似java中this引用,指代当前对象。类中的方法其必须都要有一个参数,这个参数就是self,用来指代调用该方法的当前对象,当然调用该方法时不用显示写出这个参数,python自己提供

7.2.2 类定义

一个简单的类定义如下:

__author__ = 'vincentc'
class Person :
    pass
p = Person()
print(p)

7.2.3 定义类方法示例

__author__ = 'vincentc'
class Person:
    def sayHi(self): #每个类方法,都必须定义的默认参数,指代调用该方法的当前对象,名字约定俗成为self,最好沿用这个。该方法在调用时,不用显示指定该参数,有python默认提供
        print('Hello,how are you')
p = Person()
p.sayHi()

7.2.4 初始化方法(__init__)

__init__方法用来在创建对象时,初始化一些数据,同java的构造方法类似,示例如下:

__author__ = 'vincentc'
class Person:
    def __init__(self,name):
        self.name = name
    def sayHi(self):
        print('Hello,my name is',self.name)
p = Person('Vincent')
p.sayHi()

7.2.5 类变量实例变量以及类方法和实例方法

__author__ = 'vincentc'
class Robot:
    """This is class docString."""
    #类变量,只有一份,所有实例都可以访问,一改全改
    population = 0
    def __init__(self,name):
        """This is method docString."""
        self.name = name
        Robot.population +=1
    def die(self):
        Robot.population -=1
    def sayHi(self):
        print(self.name)
    @classmethod #该标注定义类方法
    def howMany(cls):
        print(cls.population)
droid1 = Robot("R2-D2")
droid1.sayHi() #实例方法的调用方式
Robot.howMany()#类方法的调用方式

7.2.6 私有成员

约定任何名称以一个下划线开头的成员,都为私有成员,但仅仅是约定,不是强制。以两个下划线开头的为强制私有成员,如:__privatevar

7.2.7 类继承

继承的概念和写法大致跟java类似,不同的地方有:

  1. python继承的父类写在小括号里,且支持多继承,用逗号分开
  2. 子类在初始化时不会像java那样隐式调用父类的初始化方法,必须要手动显示调用
示例如下:
__author__ = 'vincentc'
class SchoolMember:
    '''Represents any school member.'''
    def __init__(self, name, age):
        self.name = name
        self.age = age
        print('(Initialized SchoolMember: {0})'.format(self.name))
    def tell(self):
        '''Tell my details.'''
        print('Name:"{0}" Age:"{1}"'.format(self.name, self.age), end=" ")
class Teacher(SchoolMember):
    '''Represents a teacher.'''
    def __init__(self, name, age, salary):
        SchoolMember.__init__(self, name, age)
        self.salary = salary
        print('(Initialized Teacher: {0})'.format(self.name))
    def tell(self):
        SchoolMember.tell(self)
        print('Salary: "{0:d}"'.format(self.salary))
class Student(SchoolMember):
    '''Represents a student.'''
    def __init__(self, name, age, marks):
        SchoolMember.__init__(self, name, age)
        self.marks = marks
        print('(Initialized Student: {0})'.format(self.name))
    def tell(self):
        SchoolMember.tell(self)
        print('Marks: "{0:d}"'.format(self.marks))
t = Teacher('Mrs. Shrividya', 40, 30000)
s = Student('Swaroop', 25, 75)
print() # prints a blank line
members = [t, s]
for member in members:
    member.tell() # works for both Teachers and Students

八,docString

docString用来描述一个类、方法、模块的用途。

8.1 定义

docString必须放在类、函数(方法)、模块的第一个逻辑行。其余公约如下:

  1. 第一行首字母大写,并且以点号结尾
  2. 第二行为空行
  3. 第三行为具体明细解释
示例:
__author__ = 'vincentc'
def printMax(x,y):
    '''Prints the maximum of two numbers.
    the two values must be integers.'''
    x = int(x)
    y = int(y)
    if x>y:
        print(x,'is maximum')
    else:
        print(y,'is maximum')
printMax(3,5)
print(printMax.__doc__)

8.2 使用

  1. 用方法、类、模块名,调用该变量,如:printMax.__doc__
  2. 用help方法自动调用,如:help(printMax)

九,输入输出

9.1 input&print

input可以用来接受用户的输入。print用来打印输出

9.2 读写文件

有多种模式可以打开文件,以读的方式,写的方式等,示例如下:

poem = '''sfsdfsdfsdfsdfsdfsdfs'''
f = open('poem.txt', 'w') # open for 'w'riting
f.write(poem) # write text to file
f.close() # close the file
f = open('poem.txt') # if no mode is specified, 'r'ead mode is assumed by default
while True:
    line = f.readline()
    if len(line) == 0: # Zero length indicates EOF
        break
    print(line, end='')
f.close() # close the file

9.3 Pickle

将python对象持久化到文件,并可从文件中提取出来,同java的序列化和反序列化类似,示例:

__author__ = 'vincentc'
import pickle
# the name of the file where we will store the object #
shoplistfile = 'shoplist.data'
# the list of things to buy #
shoplist = ['apple', 'mango', 'carrot']
# Write to the file #
f = open(shoplistfile, 'wb')
pickle.dump(shoplist, f) # dump the object to a file
f.close()
del shoplist # destroy the shoplist variable
# Read back from the storage #
f = open(shoplistfile, 'rb')
storedlist = pickle.load(f) # load the object from the file
print(storedlist)

9.4 Unicode

如何以utf-8的方式读写文件,示例(注:第一行的注释也是必须的):

# encoding=utf-8  
f = open("abc.txt", "wt", encoding="utf-8")
f.write("Imagine non-English language here")
f.close()
text = open("abc.txt", encoding="utf-8").read()

十, Exceptions

10.1 处理异常

句型为:

try:
    ....
except [exceptionName]:
    ....
else:
    ...
finally:
    ...

说明,except语句可以为多个同java类似,exceptionName为可选,如果不写表示拦截所有的Exception,else语句表示没有出现异常时执行的语句。finally表示无论是否有异常都会执行的语句,可以用来关闭文件,或网络链接等资源。当然如果出现异常将不会执行了。示例为:

try:
    text = input('Enter something --> ')
except EOFError:
    print('Why did you do an EOF on me?')
except KeyboardInterrupt:
    print('You cancelled the operation.')
else:
    print('You entered {0}'.format(text))

10.2 抛出异常

可以用raise关键字跑出一个异常对象。异常对象的类型可以是Exception类或任何Exception的子类。定义和跑出异常的示例如下:

class ShortInputException(Exception):
    '''A user-defined exception class.'''
    def __init__(self, length, atleast):
        Exception.__init__(self)
        self.length = length
        self.atleast = atleast
try:
    text = input('Enter something --> ')
    if len(text) < 3:
        raise ShortInputException(len(text), 3)
        # Other work can continue as usual here
except EOFError:
    print('Why did you do an EOF on me?')
except ShortInputException as ex:
    print('ShortInputException: The input was {0} long, expected at least {1}'\
    .format(ex.length, ex.atleast))
else:
    print('No exception was raised.')

10.3 The with statement

使用finally语句来显示的关闭文件显得不够优雅,更棒的方式是用with。示例:

with open("poem.txt") as f:
    for line in f:
        print(line, end='')

这样python自动会去关闭文件,而不需要finally了。关于with语句的解释如下:

What happens behind the scenes is that there is a protocol used by the with statement. It fetches the object returned by the open statement, let’s call it “thefile” in this case. It always calls the thefile.__enter__ function before starting the block of code under it and always calls thefile.__exit__ after finishing the block of code.

So the code that we would have written in a finally block should be taken care of automatically by the __exit__method. This is what helps us to avoid having to use explicit try..finally statements repeatedly.

------from

十一, Standard Library(标准库)

十二, 值得注意的

12.1 Lambda Forms(相当于匿名方法)

lambda接受一个表达式,并将其变成一个函数,表达式的值就是返回值。看明白了吧,这就是java中的匿名类是一个概念。一个按自定义的排序规则排序的例子如下:

points = [ { 'x' : 2, 'y' : 3 }, { 'x' : 4, 'y' : 1 } ]
points.sort(key=lambda i : i['y'])
print(points)

12.2 利用tuble赋值

让一个方法一次返回多个值,或者更方便赋值的方式如下:

Ever wished you could return two different values from a function? You can. All
you have to do is use a tuple.
>>> def get_error_details():
... return (2, 'second error details')
...
>>> errnum, errstr = get_error_details()
>>> errnum
2
>>> errstr
'second error details'
Notice that the usage of a, b =  interprets the result of
the expression as a tuple with two values.
If you want to interpret the results as (a, ), then you just
need to star it just like you would in function parameters:
>>> a, *b = [1, 2, 3, 4]
>>> a
1
>>> b
[2, 3, 4]
This also means the fastest way to swap two variables in Python is:
>>> a = 5; b = 8
>>> a, b = b, a
>>> a, b
(8, 5)

12.3 特殊方法

__init__(self, ...) This method is called just before the newly created object is returned for usage. __del__(self) Called just before the object is destroyed

__str__(self) Called when we use the print function or when str()is used.

__lt__(self, other) Called when the less than operator (<) is used. Similarly, there are special methods for all the operators (+, >, etc.)

__getitem__(self, key) Called when x[key] indexing operation is used.

__len__(self) Called when the built-in len() function is used for the sequence object.

12.4 list的牛逼用法

从已知list来生成一个新的list,新list为原list中大于2的成员乘以2组成。代码如下:

listone = [2, 3, 4]
listtwo = [2*i for i in listone if i > 2]
print(listtwo)

12.5 参数可变方法

方法可以接受tuble和dictionary做为参数,一个*表示tuble,两个**表示dictionary

There is a special way of receiving parameters to a function as a tuple or a dictionary using the * or ** prefix respectively. This is useful when taking variable number of arguments in the function. >>def powersum(power, *args):

... '''Return the sum of each argument raised to specified power.'''

... total = 0

... for i in args:

... total += pow(i, power)

... return total

...

>>powersum(2, 3, 4)

25

>>powersum(2, 10)

100

Because we have a * prefix on the args variable, all extra arguments passed to the function are stored in args as a tuple. If a ** prefix had been used instead,

the extra parameters would be considered to be key/value pairs of a dictionary

你可能感兴趣的:(Python 笔记(测试))