zoukankan      html  css  js  c++  java
  • python全栈开发 * 03 基本数据类型 * 180601

    python基本数据类型  ( int , bool , str )

    一  python基本数据类型

       (一)int ==> 整数.进行数学运算

        (二)str ==> 字符串.可保留少量数据并进行相应操作

        (三)bool ==> 判断真假.True,False

        (四)list ==> 存储大量数据.用[ ]表示

        (五)tuple==> 元组.不可以发生改变用()表示

        (六)dict ==> 字典.保存键值对,一样可以保存大量数据

        (七)set ==> 集合.保存大量数据.不可以重复,其实就是不保存value的dict

    二  整数( int )

          在python3中所有的整数都是int类型. 但在python2中如果数据量比较大. 会使用long类型. 在python3中不存在long类型

    整数可以进行的操作:

    bit_length().     计算整数在内存中占用的二进制码的长度

    十进制:                        1  2    3    4       5      6       7       8

    二进制:                        1 10  11  100  101  110   111  1000

    长度bit_length():          1   2   2      3      3     3         3       4

    三  布尔值( bool )

    取值只有True, False. bool值没有操作.

    转换问题:

    str => int        int(str)

    int => str        str(int)

    int => bool     bool(int).     0是False 非0是True

    bool=>int       int(bool)      True是1,  False是0

    str => bool     bool(str)      空字符串是False, 不空是True

    bool => str     str(bool)      把bool值转换成相应的"值"

    四  字符串( str )  

         把字符连成串,在Python中用  '  ," ,''' , """  引起来的内容被称为字符串.

      (一 )切片和索引

        1.索引. 索引就是下标.   注意  :  下标从 " 0 "开始.

        #   0 1 2 3 4 5  6  7    

    s1 = "p y  t h o n 最 牛"

    print(s1[0])    #   获取第  0 个      (  0,1,2,3,4,5,6,7 )  都可以获取.

    print(s1[8])    #    没有8,获取不了,会报错

    print(s1[-1])   #    -1  表示倒数

    print(s1[-2])   #    -2  表示倒数第二个

         2.切片. 我们可以使用下标来截取部分字符串的内容

         语法 : str[start:end:step] (起始, 结束,步长)

          规则 : 顾头不顾尾,从start开始截取.截取到end位置,但不包括end.

     #  0 1 2 3 4 5 6  78

    s2 = "p  y    t  h  o n  最 牛B"

    print(s2[0:3])     #   从 0 获取到 3 ,不包括3.==>  pyt

    print(s2[6:9])     #   最大是8,但想要取到8必须给9.

    print(s2[6:10])   #   如果右边已经过了最大值,相当于获取到最后.

    print(s2[4:])       #   如果想获取到最后,最后一个值可以不给.

    print(s2[-1:-5])   #     -1 取到 -5 ,这样是获取不到结果的,从-1向右数,数不到-5.

    print(s2[-5:-1])   #   这样能取到数据

    print(s2[-5:])      #   什么都不写就能取到最后一位  

    print(s2[:-1])      #    取到倒数第一个数

    print(s2[:])         #    原样输出

      跳着截取

    print(s2[1:5:2])   #   从第1个开始取,取到第5个,每2个取1个,结果:yh,1:5=>ytho=>yh.

    [:5:2]   #  从头取到第5个,每两个取一个.

    [4::2]   #   从第四个取到最后,每两个取一个.

    [-5::2]  #   从-5取到最后,每两位取一个.

    [-1:-5]  #   什么都没有,  (从左往右获取)

    [-1:-5:-1]   #   步长是-1,这时就是从右往左取值了.

    [-5::-3]   #   从第-5个开始,到最开始,每3个取1个,结果:oy

    步长 :  

     如果是整数,则从左往右取,如果是负数,则从右往左取,默认是1.

      (二 )字符串的相关操作方法

    切记 : 字符串是不可变的对象,所以任何操作对原字符串是不会有任何影响的

        1.大小写转来转去

    s1.capitalize()

    print(s1)   #  输出发现并并没有任何变化,因为字符串本身是不会发生变化的,需要重新获取.

    ret1=s1.cpapitalize()      #    首字母变大

    print(ret1)

    ret2=s1lower()      #  全部换小写  

    print(ret2)       

    ret3=s1upper()     #  全部换大写

    print(ret3)

    应用大写:

            verify_code="abDe"

            user_verify_code=input("请输入验证码")

            if verify_code.upper() == user_verify_code.upper():

                print("验证成功")

           else:

                print("验证失败")

    ret4=s1.swapcase()     #  大小写互相换    

    print(ret4)

    ret5=s1.casefold()         #        转换成小写,与lower区别,后者对某些字符支持不够.casefold() 对所有字母都有效.

    print(ret5)

    s2="mary egg ,taibai*yinwang_麻花"

    ret6=s2.title()     #    每个被特殊字符隔开的字母首字母大写.   中文也算特殊字符.

    print(ret6)        #      Mary Egg,Taibai*Yinwang_麻花

        2.切来切去

    ret7=s.center(10,"*")     #     拉长成10,把原字符串放中间,其余位置补*.

    print(ret7)

    ret8=s.expandtabs()       #    更改tab的长度,

    s3="mary wusir eggon"

    print(s3.expandtabs())      #   可以改变 的长度,默认长度更改为8

    ret9=s.strip()      #    strip   去左右两边空格; lstrip   去左边的空格   ; rstrip   去右边的空格.print

    应用用户登录.   也可去掉制定元素.("指定元素")

    ret10=s.replace("i","s",2  )      #    把" i "换成 "  s " ,  "2"代表替换两个.

    lst11=s.split(" ")            #     字符串切割,根据引号里的字符进行切割 ,如果切割符在左右两端,那么   一定会出现空字符串

    print(lst)

        3.格式化输出

    s12 = "我叫%s, 今年%d岁了, 我喜欢%s" % ('sylar', 18, '周杰伦')         # 之前的写法

    print(s12)

    s12 = "我叫{}, 今年{}岁了, 我喜欢{}".format("周杰伦", 28, "周润发")     #      按位置格式化

    print(s12)

    s12 = "我叫{0}, 今年{2}岁了, 我喜欢{1}".format("周杰伦", "周润发", 28)      #      指定位置

    print(s12)

    s12 = "我叫{name}, 今年{age}岁了, 我喜欢{singer}".format(name="周杰伦", singer="周润发", age=28) # 指定关键字

    print(s12)

        4.查找格式化输出

    s1 = "我叫sylar, 我喜欢python, java, c等编程语言."

    ret1 = s1.startswith("sylar")       #    判断是否以sylar开头

    print(ret1)

    ret3 = s1.endswith("语言")        #     是否以'语言'结尾

    print(ret3)

    ret4 = s1.endswith("语言.")      #      是否以'语言.'结尾

    print(ret4)

    ret7 = s1.count("a")                 #       查找"a"出现的次数

    print(ret7)

    ret5 = s1.find("sylar")              #        查找'sylar'出现的位置

    print(ret5)

    ret6 = s13.find("tory")             #          查找'tory'的位置, 如果没有返回 " -1 "

    print(ret6)

    ret7 = s13.find("a", 8, 22)       #          切片找

    print(ret7)

    ret8 = s13.index("sylar")         #           求索引位置. 注意. 如果找不到索引. 程序会报错

    print(ret8)

         5.条件判断

    s1 = "123.16"  

    print(s1.isalnum())        #  是否由字母数字组成    

    print(s1.isalpha())         #  是否由字母组成 

     print(s14.isdigit())        #  是否由阿拉伯数字

    print(s14.isnumeric())   #   中文都识别.(一二 三;   壹贰; 123)

    print(s14.isdecimal())  

    # 练习. 用算法判断某一个字符串是否是小数

    s17 = "-123.12"

    s17 = s17.replace("-", "")       #    替换掉负号

    if s17.isdigit():  

    print("是整数")

    else:

         if s17.count(".") == 1 and nots17.startswith(".") and not s17.endswith("."):

              print("是小数")

        else:  

               print("不是小数)

           6.计算字符串的长度

    s18 = "我是你的眼, 我也是a"

    ret = len(s18)         #    计算字符串的长度  是内置函数不需要加  " s."

    print(ret)

    注意: len()是python的内置函数. 所以访问方式也不一样. 你就记着len()和print()一样就行了.

        7.迭代

            我们可以使用for循环来便利(获取)字符串中的每一个字符

       语法:

               for 变量 in 可迭代对象:

                      pass

     可迭代对象: 可以一个一个往外取值的对象

    应用

    s19 = "大家好, 我是VUE, 前端的小朋友们. 你们好么?"

                用while循环

    index = 0

    while index < len(s19):

         print(s19[index]) # 利用索引切片来完成字符的查找

         index = index + 1

                for循环, 把s19中的每一个字符拿出来赋值给前面的c

    for c in s19:

        print(c)

    print('VUE' in s19)

    in有两种用法:

              1. 在for中. 是把每一个元素获取到赋值给前面的变量.

               2. 不在for中. 判断xxx是否出现在str中.

    # 练习,

    计算在字符串"I am sylar, I'm 14 years old, I have 2 dogs!"

    s20 = "I am sylar, I'm 14 years old, I have 2 dogs!"

    count = 0

    for c in s20:

        if c.isdigit():

            count = count + 1

    print(count)

     

  • 相关阅读:
    Row versus Set Processing, Surprise!(集合处理和单行处理数据的差异性)
    SVN导出增量包的方法
    Number of Digit One
    VPS+LNMP+WordPress搭建个人网站
    寻找最小的k个数(大顶堆方法)
    二叉搜索树转化为有序双向链表(C语言)
    LeetCode 345 Reverse Vowels of a String
    LeetCode 278 First Bad Version
    LeetCode 205 Isomorphic Strings
    LeetCode 88 Merge Sorted Array
  • 原文地址:https://www.cnblogs.com/J-7-H-2-F-7/p/9130308.html
Copyright © 2011-2022 走看看