首页 > 代码库 > python基础篇

python基础篇

http://www.cnblogs.com/yuanchenqi/articles/5782764.html

一、变量

  1、定义:变量用于存储要在计算机程序中引用和操作的信息。他们还提供了一种以描述性名称标注数据的方法,所以我们的程序可以被读者和我们自己更清楚地理解。将变量视为容纳信息的容器是有帮助的。它们的唯一目的是将数据标记和存储在内存中。 然后可以在整个程序中使用此数据。

  2、声明变量:name="alex"

        上述代码声明了一个变量,变量名为: name,变量name的值为:"Alex Li"

  3、变量定义规则:

    • 变量名只能是 字母、数字或下划线的任意组合
    • 变量名的第一个字符不能是数字
    • 以下关键字不能声明为变量名
      [‘and‘, ‘as‘, ‘assert‘, ‘break‘, ‘class‘, ‘continue‘, ‘def‘, ‘del‘, ‘elif‘, ‘else‘, ‘except‘, ‘exec‘, ‘finally‘, ‘for‘, ‘from‘, ‘global‘, ‘if‘, ‘import‘, ‘in‘, ‘is‘, ‘lambda‘, ‘not‘, ‘or‘, ‘pass‘, ‘print‘, ‘raise‘, ‘return‘, ‘try‘, ‘while‘, ‘with‘, ‘yield‘]

  4、变量的赋值

二、缩进

  缩进就是控制块,官方建议空四个空格,在很多语言里都是通过大括号来实现的,但是Python是通过空格

三、注释

  单行注释:#

  多行注释:""" """或‘‘‘ ‘‘‘

四、运算符

  1、算数运算符 +  -  *  /

  2、赋值运算符 =  +=  -=  *=  /=

  3、比较运算符 ==  >=  <=  !=  >  <  (一定是布尔值,用于循环)

  4、逻辑运算符 and(与)  or(或)  not(非)

  5、关系运算符 in  not in  (返回值是布尔值)

         例:print(2 in [1,2,3]

           True

  6、位运算符

五、数据类型

  1、定义:计算机顾名思义就是可以做数学计算的机器,因此,计算机程序理所当然地可以处理各种数值。但是,计算机能处理的远不止数值,还可以处理文本、图形、音频、视频、网页等各种各样的数据,不同的数据,需要定义不同的数据类型。在Python中,能够直接处理的数据类型有以下几种

  所有的数据类型一定可以划分为两种:

    可变数据类型:列表,字典

    不可变数据类型:整形,元组,字符串

    不可变数据类型如下图:

    技术分享

    再比如:i=1(在内存中创建一个数据类型)

        i=2(并不是覆盖1,而是开辟一块新的空间,写上2)  

  2、数字(整形,浮点型,布尔类型)

  

  整形

  Python3中整形(int)就是长整型,在2.x版本中才有区分

  

  浮点型(float,double)

  科学计数法,是为了节省空间,比如无线循环和不循环小数如果一直存在去电脑会崩溃

  精度要求非常高的话使用double

  例:0.000123=1.23e^(-4)

  

  布尔值

  True=1,False=0,二者可进行运算,True+False=1

 

  3、字符串(string)

  创建2种(表达式和关键字):表达式:s="zhongguo"

                 关键字:s=str("zhongguo")#涉及到类

  字符串操作:

    查找  []  [:]   #序列都可以进行切片,如字符串列表元组

    去空:strip()#把字符串的开头和结尾的空格和制表符还有换行符去掉,括号里可以加参数

    拼接:s="hello"+"world"+"I"+"am"+"python"(拼接次数多的话,效率要低,因为字符串是不可变的,显示helloworld申请一块内存空间,然后又是helloworldI申请一段内存空间,然后又是helloworldIam申请一断内存空间,一次类推)

         "".join(["a","b","c"])#join是将列表拼接成一个字符串,join参数一定是列表,列表里一定要放字符串,数字不能拼接,不是一个类型的不能拼接,""中可以加*,空格之类的其他东西

    分割:split(),正好与join相反是把字符串分割成一个列表,参数只要字符串中有的都可以加,还有最大分个数split(,)逗号后边可以规定分割次数

       splitlines是以换行符为分隔符的如果末尾有\n的话不会显示,但split会显示

    

    find(找不到返回-1)

    "hello world".find("l")#打印后返回2

    "hello world".find("l",3)#打印后返回3

    

    index(找不到报错)

    "hello world".index("l",4)#返回后打印9

    

    replace

    "hello world".replace("world","python")#完全匹配,必须一对一匹配上 

    s="hello world"

    print(s.replace("world","python"))------------->hello python

    print(s)------------------------------------------>hello world

    因为字符串是不可变的,所以hello python是开辟了一块新的空间,之前的s还是指向hello world,而后边讲到的append针对的类型是可变的,是直接对列表(只举列表这一个例子)进行修改,没有返回值,也就意味着并没有开辟新的空间,直接打印原列表即可

    

    居中显示:print("hello world".center(50,"*"))#居中显示总共50个字符,不够的用*补上

         print("hello world".ljust(50,"*"))#靠左显示,右边用*补全,总共50个字符

    字符串的格式化输出:

     "hello %s"%"sb"---------->print后输出hello sb

     %s,给字符串占位  %d,给整形占位  %f,给浮点型数据占位,%.4f小数点后保留四位(占四位)

     "hello {0},his age is {1}".format("alex",34)#按索引位对应

     "hello {name},his age is {age}."format(name="wusir",age=30)#通过键值对(推荐)

     "hello {name},his age is {age}."format_map({"name":"agon","age"=33})#通过字典

    

    关于数字判断:isdecimal(),isdigit(),isnumeric()--->返回True或者False

     isnumeric中1,一,I,壹都可以识别

    

    大小写:

    print("hello world".capitalize())----->Hello world

    print("hello world".title())------------>Hello World

    print("HEllO world".casefold())------->hello world

    print("HEllO world".lower())------->hello world

    

    expandtabs

    "HELLO\tworld".expandtabs(20)更改\t的空格数

    

    zfill:

    print("hello world".zfill(50))#其他位置都补0,内容右对齐

  

  4、列表  可迭代对象,能够进行for循环的就是可迭代对象

  创建:l=[1,"hello",[4,5],{"name":"egon"}]

     l2=list([1,23,3])

     查:切片[:]

     增:append()#可以追加字符串和列表,追加到最后,只能添加一个,不能添加多个

       print(l2.append("yuan"))#返回None因为列表为可变的,没有开辟新的空间,直接在原来的结果上进行了添加

       extend()#可以进行多个添加,如12.extend([7,8])如果是多序列的话参数必须是列表形式

       insert(2,66)#指定位置进行插入,插入的66索引值为2

     

     删:l2.pop(1)#pop参数为索引值,返回删掉的值

       l2.remove(23)#不知道索引值,通过内容删除

       del 12[2]#最霸道的删除

       del l2#可直接删掉列表   del l2[1,3]#可以分段删

     改:l2[0]="yuan"

     清空:l2.clear()#清空就是把里面的值全清空,效率低

        l2=[]#(推荐)与上面的不一样,这个是把l2重新指向了一个新的地址,所以和上面的内存地址肯定不一样

     计数:l2.count(3)#返回值是1,判断列表里有几个3

     长度:len(l2)#返回值是3,判断l2中有几个元素

     排序:sort  l3=[3,1,56,34]

            l3.sort()#.方法,默认reverse=False要从大到小排:l3.sort(reverse=True)

            print(l3)

        sorted   print(sorted(l3))#函数方法

     拷贝:深拷贝和前拷贝

  5、字典(哈希算法可哈希就是可以进行哈希算法 反之就是不可以 可以进行哈希算法的数据就是不可变类型的,如果是不可变的,在对对象本身操作的时候,必须在内存的另外地方再申请一块区域(因为老区域#不可变#),老的区域 就丢弃了(如果还有其他ref,则ref数字减1,类似unix下的hard-link)。如果是可变的,对对象操作的时候,不需要再在其他地方申请内 存,只需要在此对象后面连续申请(+/-)即可,也就是它的address会保持不变,但区域会变长或者变短。

)无序的

    Python中唯一具有映射关系的数据类型,字典的查询速率要远高于列表,好比一页一翻得找和找到对应的页码直接找页码,但是字典的存储空间较大,比列表多了一张映射表,总之,是用空间取换取时间

    创建:d={"name":"alex","name":"egon"}#打印结果会以后面的结果为准,就是前边的被覆盖了,白写。键唯一且为不可变数据类型,如元组、字符串、整形

    查:d["name"]

      d.get("name",None)#推荐,如果字典里没有的话返回None,可以换成一些其他的东西比如False

      for i in dict循环遍历的是字典的key

      for i in dict:

        print("%s---->%s"%(i,d[i]))#格式化输出

    增:d["gao"]="luchuan"

    改:d["name"]="yuan"

    删:d.pop("1")#返回删掉的value值

  6、集合set  两个功能:去重,关系测试。 可变数据类型

     set集合内元素一定是不可变数据类型

     关系测试:s1={"hello",1,2,3}

          s2={1,2,("a","b")}

    求并集:print(s1.union(s2))

        print(s1|s2)#顺序没关系    

    求交集:print(s1.intersection(s2))

        print(s1&s2)

    求差集:print(s1.difference(s2))#s1中有的,s2中没有的

        print(s1-s2)

        print(s2.difference(s1))#s2中有的,s1中没有的

        print(s2-s1)

    求对称差集:print(s1.symmetric_difference(s2))#互相都没有的

          print(s1^s2)   

  7、元组tuple  (不能进行修改操作)

    查: 切片 [:] 

     

 

 

       

    

  

  

  

python基础篇