python学习笔记(一)续

1、在交互式解释器中,给变量赋值(字符串,数值等等)并通过输入变量名显示它们的值。再用 print 语句做同样的事。区别在于:变量赋值是数值时没有区别;当变量赋值是字符串时,通过变量名显示它们的值的形式是将字符串以单引号括起来,而用print语句则是直接显示字符串。

在python中格式化输出字符串使用的是%运算符,通用的形式为:格式标记字符串 % 要输出的值组;左边部分的最简单形式为:%cdoe,右边的‘值组‘如果有两个及以上的值则需要用小括号括起来,中间用短号隔开。带百分号格式化的

Python 2.x:print "old %s version is %d, print no ()"%("Python", 2);  #

Python 3.x:print("new %s version is %d, print must have ()"%("Python", 3));

Python 2.x和Python 3.x中print函数语法方面的区别:

Python 2.x: print “所要打印的内容” , 不带括号

Python 3.x: print函数(”所要打印的内容”),必须带括号

注:在脚本中想进行输出,需使用print语句;python中默认的True和False。

2、python2.x中raw_input( )和input( ),两个函数都存在,其中区别为:

raw_input( )---将所有输入作为字符串看待,返回字符串类型input( )-----只能接收“数字”的输入,在对待纯数字输入时具有自己的特性,它返回所输入的数字的类型( int, float )

python3.x中raw_input( )和input( )进行了整合,去除了raw_input( ),仅保留了input( )函数,其接收任意任性输入,将所有输入默认为字符串处理,并返回字符串类型。

3.求和

先根据用户输入分别创建一个元组与列表:

a=input("Please enter some number:")   #如用户输入:1,2,3,4
numl=eval(a)   #create a tuple;(1,2,3,4)
numt=a.split(‘,‘)   #create a list;[‘1’,‘2’,‘3’,‘4’],用int()转换成数值型

再利用循环进行求和

i=0

sum=0

while i<len(numl):
  sum=sum+numl[i]
  print(sum)
  i+=1

或者使用for循环:

total=0

for i in numt:
  total=total+int(i)
  print(total)

4.Python3 内置函数(转:http://www.cnblogs.com/chenice/articles/6121282.html)

(1)abs(),   绝对值或复数的模

1 print(abs(-6))#>>>>6

(2)all()  接受一个迭代器,如果迭代器的所有元素都为真,那么返回True,否则返回False

1 print(all([1,0,3,6]))#>>>>False

(3)any()  接受一个迭代器,如果迭代器里有一个元素为真,那么返回True,否则返回False

1 print(any([0,0,0,[]]))#>>>>False

(4)ascii()  调用对象的__repr__()方法,获得该方法的返回值.

1 print(ascii([1,2,3,1,22,123]))#>>>>>[1, 2, 3, 1, 22, 123]

(5) bin(),将十进制转换为二进制

1 print(bin(10))#>>>>>0b1010

(6)oct(),将十进制转换为八进制

1 print(oct(7))#>>>>>>0o7

(7)hex(),将十进制转换为十六进制

1 print(hex(15))#>>>>>>0xf

(8)bool()  测试一个对象是True还是False.

1 print(bool([]))#>>>>>False

(9)bytes()  将一个字符串转换成字节类型

1 s="apple"
2 v=bytes(s,encoding="utf-8")
3 print(v)#>>>>>>b‘apple‘

(10)str()  将字符类型/数值类型等转换为字符串类型

1 s=100
2 print(type(s))#>>>><class ‘int‘>
3 s=str(s)
4 print(type(s))#>>>><class ‘str‘>

(11)challable()  判断对象是否可以被调用,能被调用的对象就是一个callables对象,比如函数

1 print(callable(str))#>>>>>True

(12)chr()查看十进制数对应的ASCII字符

(13)ord(),查看某个ascii对应的十进制数

1 print(ascii(12323))#>>>>12323

(14)classmethod()  用来指定一个方法为类的方法,由类直接调用执行,只有一个cls参数,执行类的方法时,自动将调用该方法的类赋值给cls.没有此参数指定的类的方法为实例方法。

(15)complie()  将字符串编译成python能识别或可以执行的代码,也可以将文字读成字符串再编译。

    compile(source, filename, mode, flags=0, dont_inherit=False, optimize=-1)

    将source编译为代码或者AST对象。代码对象能过通过exec语句来执行或者eval()进行求值。

参数source:字符串或者AST(abstract syntax trees)对象。

参数filename:代码文件名称,如果不是从文件读取代码则传递一些可辨认的值。

   参数model:指定编译代码的种类。可以指定‘exec‘‘eval‘‘single‘

参数flag和dont_inherit:这两个参数为可选参数。

1 s  = "print(‘helloworld‘)"
2 r = compile(s, "<string>", "exec")
3 print(r)#>>>>>>><code object <module> at 0x0000000000B426F0, file "<string>", line 1>

(16) complex(),创建一个值为real + imag * j的复数或者转化一个字符串或数为复数。如果第一个参数是字符串,则不需要指定第二个参数。

1 print(complex("123"))#>>>>(123+0j)

(17)delattr()  删除对象的属性

(18)dict()  创建数据字典

1 print(dict())#>>>>>>{}

(19)dir()  不带参数时返回当前范围内的变量,方法和定义的类型列表,带参数时返回参数的属性,方法列表。

1 print(dir())#>>>>>[‘__builtins__‘, ‘__cached__‘, ‘__doc__‘, ‘__file__‘, ‘__loader__‘, ‘__name__‘, ‘__package__‘, ‘__spec__‘, ‘r‘, ‘s‘]

(20)divmod()  分别取商和余数

1 print(divmod(10,3))#>>>>>(3, 1)

(21)enumerate()  返回一个可以枚举的对象,该对象的next()方法将返回一个元组。

1 s = ["a","b","c"]
2 for i ,v in enumerate(s,1):
3     print(i,v)#>>>>>1 a  2 b   3 c

(22)eval()  1.将字符串str当成有效的表达式来求值并返回计算结果2.取出字符串中内容

1 s = "1 + 3 +5"
2 print(eval(s))#>>>>>>9

(23)exec()  执行字符串或complie方法编译过的字符串,没有返回值

(24)filter()  过滤器,构造一个序列,等价于[ item for item in iterables if function(item)],在函数中设定过滤条件,逐一循环迭代器中的元素,将返回值为True时的元素留下,形成一个filter类型数据。

filter(function, iterable)

参数function:返回值为TrueFalse的函数,可以为None

参数iterable:序列或可迭代对象。

1 def uno(x):
2     return x > 10
3 v=filter(uno,[1,11,2,45,7,6,13])
4 print(v)#>>>>><filter object at 0x0000000001143160>

(25)float()  讲一个字符串或整数转换为浮点数。

1 print(float(11))#>>>>>11.0

(26)format()  格式化输出字符串,format(value, format_spec)实质上是调用了value的__format__(format_spec)方法。

1 print("i am {0},age{1}".format("tom",18))#>>>>>>i am tom,age18

(27)frozenset()  创建一个不可修改的集合。

frozenset([iterable])

setfrozenset最本质的区别是前者是可变的,后者是不可变的。当集合对象会被改变时(例如删除,添加元素),只能使用set

一般来说使用fronzet的地方都可以使用set

参数iterable:可迭代对象。

(28)getattr()  获取对象的属性

getattr(object, name [, defalut])

获取对象object名为name的特性,如果object不包含名为name的特性,将会抛出AttributeError异常;如果不包含名为name的特性

且提供default参数,将返回default。

参数object:对象

参数name:对象的特性名

参数default:缺省返回值

(29)globals()  返回一个描述当前全局变量的字典

1 a = "apple"
2 print(globals())#>>>>>{‘__name__‘: ‘__main__‘, ‘__package__‘: None, ‘__cached__‘: None, ‘a‘: ‘apple‘, ‘__loader__‘: <_frozen_importlib_external.SourceFileLoader object at 0x00000000006A5B70>, ‘__file__‘: ‘D:/pycharm/pythonS3/内置函数.py‘, ‘__spec__‘: None, ‘__builtins__‘: <module ‘builtins‘ (built-in)>, ‘__doc__‘: None}

(30)hasattr(),hasattr(object,name)判断对象object是否包含名为name的特性(hasattr是通过调用getattr(object,name))是否抛出异常来实现的。

1 print(hasattr(dict,"get"))#>>>>True

(31) hash()  哈希值hash(object)注意:可哈希的即不可变数据类型,不可哈希即可变数据类型

如果对象object为哈希表类型,返回对象object的哈希值。哈希值为整数,在字典查找中,哈希值用于快递比价字典的键。

两个数值如果相等,则哈希值也相等。

(32)help()  返回对象的帮助文档

调用内建的帮助系统,如果不包含参数,交互式帮助系统将在控制台启动。如果参数为字串,则可以是模块,类,方法等名称,并且帮助页面将会在控制台打印。参数也可以         为任意对象

(33)id()  返回对象的内存地址

1 a = 1
2 print(id(a))#>1519780304

(34) input()  获取用户输入内容

1 print(input("aaa"))#>>>>>aaa

(35) int()  将一个字符串或数值转换为一个普通整数int([x[,radix]])

如果参数是字符串,那么它可能包含符号和小数点。参数radix表示转换的基数(默认是10进制)。

它可以是[2,36]范围内的值,或者0。如果是0,系统将根据字符串内容来解析。

如果提供了参数radix,但参数x并不是一个字符串,将抛出TypeError异常;

否则,参数x必须是数值(普通整数,长整数,浮点数)。通过舍去小数点来转换浮点数。

如果超出了普通整数的表示范围,一个长整数被返回。

如果没有提供参数,函数返回0

1 s = "123"
2 print(type(s))#>>>>><class ‘str‘>
3 s=int(s)
4 print(type(s))#>>>>><class ‘int‘>

(36) isinstance()  检查对象是否是类的对象,返回True或False,isinstance(obj, cls)

检查obj是否是类cls的对象, 返回True 或 False

1 class Foo(object):
2     pass
3 obj = Foo()
4 print(isinstance(obj, Foo))#>>>>>True

(37)issubclass()  检查一个类是否是另一个类的子类。返回True或False,,,issubclass(sub, super)

检查sub类是否是super类的派生类(子类)。返回True 或 False

1 class Foo(object):
2     pass
3 class Bar(Foo):
4     pass
5 print(issubclass(Bar, Foo))#>>>>>>True

(38)iter(),iter(o[, sentinel])

返回一个iterator对象。该函数对于第一个参数的解析依赖于第二个参数。

如果没有提供第二个参数,参数o必须是一个集合对象,支持遍历功能(__iter__()方法)或支持序列功能(__getitem__()方法),

参数为整数,从零开始。如果不支持这两种功能,将处罚TypeError异常。

如果提供了第二个参数,参数o必须是一个可调用对象。在这种情况下创建一个iterator对象,每次调用iterator的next()方法来无

参数的调用o,如果返回值等于参数sentinel,触发StopIteration异常,否则将返回该值。

(39)len()  返回对象长度,参数可以是序列类型(字符串,元组或列表)或映射类型(如字典)

1 s = "ajljflajfl"
2 print(len(s))#>>>>>10

(40)list()  列表构造函数。

(41)locals()  打印当前可用的局部变量的字典

(42)map(),map(function, iterable,...)

对于参数iterable中的每个元素都应用fuction函数,并将结果作为列表返回。

如果有多个iterable参数,那么fuction函数必须接收多个参数,这些iterable中相同索引处的元素将并行的作为function函数的参数。

如果一个iterable中元素的个数比其他少,那么将用None来扩展改iterable使元素个数一致。

如果有多个iterable且function为Nonemap()将返回由元组组成的列表,每个元组包含所有iterable中对应索引处值。

1 li = [1,2,3]
2 data = map(lambda x :x*100,li)
3 print(type(data))#>>>>>><class ‘map‘>
4 data = list(data)
5 print(data)#>>>>>>>[100, 200, 300]

(43)max()  返回给定元素里最大值,max(iterable [,args...][, key])

如果只提供iterable参数,函数返回可遍历对象(如:字符串,元组或列表)中最大的非空元素。

如果提供多个参数,那么返回值最大的那个参数。

可选参数key是单参数的排序函数。

如果提供key参数,必须是以命名的形式,如:max(a, b, c, key = fun)

(44)meoryview()

(45) min()  返回给定元素里最小值,min(iterable [,args...][, key]),具体用法跟max()相同

(46)next()  返回一个可迭代数据结构(如列表)中的下一项

(47)object(),获取一个新的,无特性(geatureless)对象。Object是所有类的基类。它提供的方法将在所有的类型实例中共享。

(48)open()  打开文件open(filename [, mode [, bufsize]])

打开一个文件,返回一个file对象。 如果文件无法打开,将处罚IOError异常。

应该使用open()来代替直接使用file类型的构造函数打开文件。

参数filename表示将要被打开的文件的路径字符串;

参数mode表示打开的模式,最常用的模式有:‘r‘表示读文本,‘w‘表示写文本文件,‘a‘表示在文件中追加。

Mode的默认值是‘r‘

当操作的是二进制文件时,只要在模式值上添加‘b‘。这样提高了程序的可移植性。

可选参数bufsize定义了文件缓冲区的大小。0表示不缓冲;1表示行缓冲;任何其他正数表示使用该大小的缓冲区;

负数表示使用系统默认缓冲区大小,对于tty设备它往往是行缓冲,而对于其他文件往往完全缓冲。如果参数值被省却。

使用系统默认值。

(49)pow(x,y,z)  幂函数,表示取x得y次幂,如果存在第三个参数z,则表示乘方结果对第三个参数取余

1 s=pow(2,8,)
2 print(s)#>>>>256
3 s2=pow(2,8,5)
4 print(s2)#>>>>>1

(50)print()  输出函数

(51)property()

(52)range()  根据需要生成一个指定范围的数字,可以提供你需要的控制来迭代指定的次数

用于创建包含连续算术值的列表(list)。常用于for循环。参数必须是普通整数。

参数step默认值为1,参数start的默认值为0

全参数调用该函数将返回一个普通整数列表。

step 可以是正整数或者负整数。不可以为0,否则将触发ValueError异常。

(53)repr()  将任意值转换为字符串,供计时器读取的形式  repr(object)

返回一个对象的字符串表示。有时可以使用这个函数来访问操作。

对于许多类型来说,repr()尝试返回一个字符串,eval()方法可以使用该字符串产生对象;

否则用尖括号括起来的,包含类名称和其他二外信息的字符串被返回。

(54)reversed()   反转,逆序对象

(55)round()  四舍五入round(x [, n])

对参数x的第n+1位小数进行四舍五入,返回一个小数位数为n的浮点数。

参数n的默认值是0。结果是一个浮点数。如round(0.5)结果为1.0

(56)set(),将对象转换成集合

(57)setattr()  与getattr()相对应

(58)slice()  切片功能

1 s = ["a","b""c","d"]
2 print(slice(1,3,s))

(59)sorted()  排序

列表排序,按数轴方向排

高阶函数,以绝对值大小排序

字符串排序,按照ASCII的大小排序

如果需要排序的是一个元组,则需要使用参数key,也就是关键字。

反向排序,reserve=True

(60)sum()  求和

(61)tuple()  元组构造函数

(62)type()  显示对象所属的类型

(63)zip()  将对象逐一配对

时间: 2024-10-14 00:44:51

python学习笔记(一)续的相关文章

OpenCV之Python学习笔记

OpenCV之Python学习笔记 直都在用Python+OpenCV做一些算法的原型.本来想留下发布一些文章的,可是整理一下就有点无奈了,都是写零散不成系统的小片段.现在看 到一本国外的新书<OpenCV Computer Vision with Python>,于是就看一遍,顺便把自己掌握的东西整合一下,写成学习笔记了.更需要的朋友参考. 阅读须知: 本文不是纯粹的译文,只是比较贴近原文的笔记:         请设法购买到出版社出版的书,支持正版. 从书名就能看出来本书是介绍在Pytho

python学习笔记12-模块使用

python学习笔记12-模块使用 模块os,sys 什么是模块? 模块os,sys 模块是Python组织代码的一种基本方式 一个Python脚本可以单独运行,也可以导入到另外一个脚本运行,用import hello语句来导入,不用加入.py 什么是Python的 包? Python的模块可以按照目录组织为包 创建一个包的步骤: 创建一个名字为包名的目录 在改目录下创建一个__init__.py文件 根据需要,在该目录下存放脚本文件或已编译的扩展及子包 import pack.m1,pack.

python学习笔记2—python文件类型、变量、数值、字符串、元组、列表、字典

python学习笔记2--python文件类型.变量.数值.字符串.元组.列表.字典 一.Python文件类型 1.源代码 python源代码文件以.py为扩展名,由pyton程序解释,不需要编译 [[email protected] day01]# vim 1.py #!/usr/bin/python        print 'hello world!' [[email protected] day01]# python 1.py hello world! 2.字节代码 Python源码文件

Python学习笔记--未经排版

Python 学习笔记 Python中如何做到Print() 不换行 答:Print("输出内容",end='不换行的分隔内容'),其中end=后面为2个单引号 注:在Python 2.x中,Print "输出内容", 即在输出内容后加一逗号 Python中 is 和 == 的区别 答:Python中的对象包含三要素:id.type.value 其中id用来唯一标识一个对象,type标识对象的类型,value是对象的值 is判断的是a对象是否就是b对象,是通过id来

Python学习笔记_Python对象

Python学习笔记_Python对象 Python对象 标准类型 其他内建类型 类型对象和type类型对象 Python的Null对象None 标准类型操作符 对象值的比较 对象身份比较 布尔类型 标准类型的内建函数 typeObj cmpobj1 obj2 strobj reprobj typeobj isinstanceobj 标准类型的分类 存储模型 更新模型 访问模型 不支持的类型 Python学习笔记_Python对象 首先来理解一个通俗的含义,什么是对象?其实对象无论在什么语言里面

OpenCV for Python 学习笔记 三

给源图像增加边界 cv2.copyMakeBorder(src,top, bottom, left, right ,borderType,value) src:源图像 top,bottem,left,right: 分别表示四个方向上边界的长度 borderType: 边界的类型 有以下几种: BORDER_REFLICATE # 直接用边界的颜色填充, aaaaaa | abcdefg | gggg BORDER_REFLECT # 倒映,abcdefg | gfedcbamn | nmabcd

python 学习笔记 14 -- 常用的时间模块之datetime

书接上文,前面我们讲到<常用的时间模块之time>,这次我们学习datetime -- 日期和时间值管理模块 使用apihelper 查看datetime 模块,我们可以看到简单的几项: date       ---  日期对象,结构为date(year, month, day) time       ---  时间值对象,结构为 time([hour[, minute[, second[, microsecond[, tzinfo]]]]]).时间对象所有的参数都是可选的.tzinfo 可以

python 学习笔记 6 -- 异常处理

当你的程序中出现某些 异常的 状况的时候,异常就发生了.例如,当你想要读某个文件的时候,而那个文件不存在.或者在程序运行的时候,你不小心把它删除了. 那么如果你是在IDE中运行,一个错误发生,异常会被打引出来,这便是未处理异常:当异常发生时,如果没有代码去关注和处理它,这些异常会传给置在Python中的缺省处理,他会输出一些调试信息并且终止运行.如果是在IDE中,这不是什么大事,但是如果是Python程序运行中的异常,它会导致整个程序终止,对于这些情况可以使用异常来处理. 1.try..exce

python 学习笔记 3 -- 数据结构篇上

数据结构是可以处理一些 数据 的 结构 .或者说,它们是用来存储一组相关数据的.在Python中有三种内建的数据结构--列表.元组和字典.本文主要对这三种数据类型以及相关的使用做介绍,以例子的形式演示更加容易理解! 1.列表(List) 列表是处理一组有序项目的数据结构,即你可以在一个列表中存储一个 序列 的项目.在Python中,你在每个项目之间用逗号分割. 列表中的项目应该包括在**方括号**中,这样Python就知道你是在指明一个列表.一旦你创建了一个列表,你可以添加.删除或是搜索列表中的

python 学习笔记 3 -- 数据结构篇下

5.引用 当你创建一个对象并给它赋一个变量的时候,这个变量仅仅 引用 那个对象,而不是表示这个对象本身!也就是说,变量名指向你计算机中存储那个对象的内存.这被称作名称到对象的绑定.eg. [python] view plaincopy # -*- coding: utf-8 -*- shoplist = ['apple', 'mango', 'carrot', 'banana'] print "we copy the shoplist to mylist directly \"with