python学习—基础

python目录中有两个关键性的目录:lib和Script java

lib:包含了python的内置模块;当下载的第三方模块则在lib\site-packages内; python

Script:包含了脚本exe文件;etc : pip.exe;easy_install.exe等; linux


python安装第三方模块的方式汇总: 算法

1、方法1: 单文件模块
直接把文件拷贝到 $python_dir/Lib/site-packages/ api

2、方法2: 多文件模块,带setup.py
下载模块包,进行解压,进入模块文件夹,执行:
python setup.py install
数组

3、 方法3:easy_install 方式
先下载ez_setup.py,运行python ez_setup 进行easy_install工具的安装,以后就可使用easy_install进行安装package了。
easy_install packageName
easy_install package.egg
数据结构

4、 方法4:pip 方式
先进行pip工具的安裝:easy_install pip(pip 能够经过easy_install 安裝,并且也会装到 Scripts 文件夹下。)
        安裝:pip install PackageName
        更新:pip install -U PackageName
        移除:pip uninstall PackageName
        搜索:pip search PackageName
        帮助:pip help
app

注:当前建议使用pip进行安装第三方模块 函数

python的基本数据类型: 工具

  • 空(None)
    表示该值是一个空对象,相似于java中的Null
  • 布尔类型(Boolean)                                              
    在Python中,None、任何数值类型中的0、空字符串“”、空元组()、空列表[]、空字典{}都被看成False,还有自定义类型,若是实现了__nonzero__()或__len__()方法且方法返回0或False,则其实例也被看成False,其余对象均为True
  • 整形(Int)                                                      
    在Python内部对整数的处理分为普通整数和长整数,普通整数长度为机器位长,一般都是32位,超过这个范围的整数就自动当长整数处理,而长整数的范围几乎彻底没限制
    整形作取余和除算法的时候,按floor取值:
    17/10 # 1
    17/-10 # -2
    -17/10 # -2
    
    17%10 # 7
    17%-10 # -3
    -17% 10 # 3

  • 浮点数(float)                                          
    Python的浮点数就是数学中的小数,相似C语言中的double。之因此称之为浮点数,便是由于用科学计数法表示时,浮点数中的小数点是能够变更的;如:
    1.2e8  <==> 0.12e9
    注:在运算中,整数与浮点数运算的结果是浮点数

  • 字符串(String)
    Python字符串便可以用单引号也能够用双引号括起来,甚至还能够用三引号括起来
    'ab c' # 有四个字符:a、b、空格、c
    'i\'m ok' # \用来作转义字符
    r'\\\t\\\' # r表示''内部的字符串默认不转义
  • 针对字符串的操做:
    # 去空格及特殊符号
    # strip:在首尾部分去除指定的字符串;当没有指定字符时,去除首尾空格
    # lstrip: 去除左边的指定字符串
    # rstrip:去除右边的指定字符串
    theString = 'saaaay yes no yaaaass'
    print theString.strip('say') 
    print theString.strip('say ') #say后面有空格 
    print theString.lstrip('say') 
    print theString.rstrip('say') 
    
    结果:
    yes no 
    es no 
    yes no yaaaass 
    saaaay yes no
    
    # 字符串包含 判断操做符:in,not in
    
    # string模块,还提供了不少方法,如
    S.find(substring, [start [,end]]) #可指范围查找子串,返回索引值,不然返回-1
    S.rfind(substring,[start [,end]]) #反向查找
    S.index(substring,[start [,end]]) #同find,只是找不到产生ValueError异常
    S.rindex(substring,[start [,end]])#同上反向查找
    S.count(substring,[start [,end]]) #返回找到子串的个数
    
    S.lowercase()
    S.capitalize()      #首字母大写
    S.lower()           #转小写
    S.upper()           #转大写
    S.swapcase()        #大小写互换
    S.split(str, ' ')   #将string转list,以空格切分
    S.join(list, ' ')   #将list转string,以空格链接
    
    处理字符串的内置函数
    len(str)                #串长度
    cmp("my friend", str)   #字符串比较。第一个大,返回1
    max('abcxyz')           #寻找字符串中最大的字符
    min('abcxyz')           #寻找字符串中最小的字符
    
    string的转换
                
    oat(str) #变成浮点数,float("1e-1")  结果为0.1
    int(str)        #变成整型,  int("12")  结果为12
    int(str,base)   #变成base进制整型数,int("11",2) 结果为2
    long(str)       #变成长整型,
    long(str,base)  #变成base进制长整型,


  • 列表(List)
    用符号[]表示列表,中间的元素能够是任何类型,用逗号分隔。list相似C语言中的数组,用于顺序存储结构;list取元素能够顺序也能够倒序取;如:
  • list = ['a', 'b', 'c']
    print list[2] # 取list中的最后一个元素,len(list)-1便是list最后一个元素的位置
    print list[-1] # 倒数第一个元素
    print len(list) # 得到list中元素的个数
    
    #--------list是可变的有序表,因此能够动态的增删改查list中的元素
    list.append('d') # 默认追加到尾元素 a,b,c,d
    list.insert(0, 'd') # 指定索引添加元素 d,a,b,c
    在列表中插入一个值
    sample_list[0:0] = ['sample value']
    list.pop(...) # pop不带参数默认删除尾元素,参数指定list元素索引,#返回最后一个元素,并从list中删除
    list.remove(var)   #删除第一次出现的该元素
    L.count(var)    #该元素在列表中出现的个数
    L.index(var)    #该元素的位置,无则抛异常 
    L.extend(list)  #追加list,即合并list到L上
    L.sort()        #排序
    L.reverse()     #倒序
    [1,2]+[3,4] #为[1,2,3,4]。同extend()
    [2]*4       #为[2,2,2,2]
    del L[1]    #删除指定下标的元素
    L1 = L[:]   #L1为L的克隆,即另外一个拷贝。
    用in语法判断list是否包含该元素
    print 1 in list
    list[0] = 'e' # 直接替代元素 e,b,c  # list中的数据类型能够不一致,相似java中的数组,list中能够包含list
  • 元祖(tuple)
    元组是和列表类似的数据结构,但它一旦初始化就不能更改,速度比list快,同时tuple不提供动态内存管理的功能,需理解一下规则:
    tuple能够用下标返回一个元素或子tuple
    表示只含有一个元素的tuple的方法是:(d,)后面有个逗号,用来和单独的变量相区分
    tuple = (1, 'a', ['x', 'b'])
    print tuple # 1, 'a', ['x', 'b']
    tuple[2][0] = 'y'
    tuple[2][1] = 'c'
    print tuple # (1, 'a', ['y', 'c']) # 发现tuple中元素有变,其实tuple指定的list内存地址是没有变化的,变化的是list中的元素
  • 集合(Set)
    集合是无序的,不重复的元素集,相似数学中的集合,可进行逻辑运算和算术运算

    set和dict相似,也是一组key的集合,但不存储value。因为key不能重复,因此,在set中,没有重复的key。

    要建立一个set,须要提供一个list做为输入集合:

    >>> s = set([1, 2, 3]) >>> s set([1, 2, 3])
    注意,传入的参数[1, 2, 3]是一个list,而显示的set([1, 2, 3])只是告诉你这个set内部有1,2,3这3个元素,显示的[]不表示这是一个list。
    能够经过add,remove添加和删除元素
    set和dict的惟一区别仅在于没有存储对应的value,可是,set的原理和dict同样,因此,一样不能够放入可变对象,由于没法判断两个可变对象是否相等,也就没法保证set内部“不会有重复元素”。试试把list放入set,看看是否会报错
  • 字典(dict)
    字典是一种无序存储结构,包括关键字(key)和关键字对应的值(value)。字典的格式为:dictionary = {key:value}。关键字为不可变类型,如字符串、整数、只包含不可变对象的元组,列表等不可做为关键字。若是列表中存在关键字对,能够用dict()直接构造字典
    dict中的元素能够动态经过key增长,因为一个key只能对应一个value;当后key相同时,后面的value会将前面的值进行重置;
    dict = {'java': 'diffcult', 'python':'middle'}
    print dict['java'] # diffcult
    print dict.get('java') # diffcult
    dict.pop('java')
    print dict # {'python': 'middle'}
    dict定义的方式和特性:
    info = dict(name = 'old') # {'name':'cold'} # 更优雅
    info = {'name': 'old'} # {'name':'cold'} 
    
    key = 'name'
    info = {key: 'old'} # {'name':'cold'}
    info = dict(key='old') # {'key':'cold'}
    
    #Python字典还有一种初始化方式,就是使用字典的fromkeys方法能够从列表中获取元素做为#键并用None或fromkeys方法的第二个参数初始化
    info = {}.fromkeys(['name', 'blog']) # {'blog': None, 'name': None}
    info = dict().fromkeys(['name', 'blog']) # {'blog': None, 'name': None}
    info = dict().fromkeys(['name', 'blog'], 'linuxzen.com') # {'blog': 'linuxzen.com', 'name': 'linuxzen.com'}
    
    # 可是若是获取不存在的键的值就会触发的一个KeyError异常,字典有一个get方法,可使用字典get方法更加优雅的获取字典
    info.get(key) # None
    
    #咱们看到使用get方法获取不存在的键值的时候不会触发异常,同时get方法接收两个参数,#当不存在该键的时候就会返回第二个参数的值 咱们能够看到使用get更加的优雅
    info.get(key, default) # default
    
    # 同时Python字典的update方法也能够更新和添加字典
    info = dict(name='cold', blog='linuxzen.com')
    info.update({'name':'cold night', 'blogname':'linuxzen'})
    info.update(name='cold', blog='www.linuxzen.com') # 更优雅
    
    结果:
    {'blog': 'www.linuxzen.com', 'name': 'cold', 'blogname': 'linuxzen'}
    
    # 字典删除
    del info['name']
    info.pop('name')
    # 字典查找
    info.has_key(key)      #有该键返回TRUE,不然FALSE
    info..clear()           #清空字典,同del dict 
    info.copy()      #拷贝字典
    info.cmp(dict1,dict2)  #比较字典,(优先级为元素个数、键大小、键值大小)  #第一个大返回1,小返回-1,同样返回0


    和list比较,dict有如下几个特色:
  • 查找和速度极快,不会随着key的增长而增长
  • 须要占用大量的内存,内存浪费多
    而list相反:
  • 查找和插入的时间随着元素的增长而增长
  • 占用空间小,浪费内存不多

    python有内置模块types:
    NoneType = type(None)
    TypeType = type
    ObjectType = object
    IntType = int
    LongType = long
    FloatType = float
    BooleanType = bool
    StringType = str
    BufferType = buffer
    TupleType = tuple
    ListType = list
    DictType = DictionaryType = dict
    ClassType = type(_C)
    InstanceType = type(_x)
    FileType = file


  • 常见的函数:
  • range(5) : 生成大于等于0,小于5的整形;
  • raw_input() :读取的内容永远以字符串显示返回
  • abs() : 取绝对值,只能传一个参数,且参数类型是整形或浮点型
  • cmp(x,x): 比较函数,须要两个参数
  • int(),float(),str(),unicode(),bool(): 数据类型转换
  • isinstance(x,int): 数据类型进行检查,判断该数据是否为某种类型
  • 函数中的return返回的是tuple类型
  • capitalize() : str对象的方法,将字符串首字母大写,其它为小写的方法
  • type(): 判断对象类型
  • dict(): 若是要得到一个对象的全部属性和方法,可使用dir()函数,它返回一个包含字符串的list
  • len():获取一个对象的长度
相关文章
相关标签/搜索