• Python全栈开发,Day3


    一、基本数据类型

    基础数据类型,有7种类型,存在即合理。

      1.int 整数

     主要是做运算的。比如加减乘除,幂,取余 + - * / **  % ...

      2.bool 布尔值

     判断真假以及作为条件变量

      3.str 字符串

     存储少量的数据。‘太白’,‘password’...操作简单,便于传输。

      4.list 列表

     [1,2,‘alex’,{name:‘zhang’}]存放大量的数据,大量的数据放到列表中便于操作

      5.tuple 元组

     也叫只读列表。(1,2,‘alex’,{name:'zhang'})一些重要的数据或者不想被更改的数据,使用元组

      6.dict 字典

     {‘name_list’:“[zhang,lisi”]},存储关系型的数据,查询速度非常快,二分查找。

      7.set 集合

     交集,并集,差集

    分别举例

      int整形

    i = 4
    #转化成二进制的最小位数
    print(i.bit_length())
    ...
    1   0000 0001
    1   0000 0010
    3   0000 0011
    4   0000 0100
    '''
    

     数据类型转换:

      int --> str

    n = str(1)
    

       int --> bool

    n = bool(1)
    

       str --> bool

    n = bool(' ')
    

       空字符串是False,其他都是True!!!

    str字符串索引与切片

      字符串是有序的,有索引的,索引从0开始,默认取值是从左至右

    s = 'python是最好的语言'
    #取第一个字符
    s1 = s[0]
    #取索引值为2的元素
    s2 = s[2]
    #最后一个
    s3 = s[-1]
    print(s1)
    print(s2)
    print(s3)
    

     语法:

    [起始索引:截止索引:步长]

    步长默认为1,表示从头开始取;切片,也就是取连续的多个值。切片原则,顾头不顾尾!!!

    s = 'python是最好的语言'
    s1 = s[0:2]
    print(s1)
    

     先看字符串的索引对应

    p  y  t  h  o  n

    ↓  ↓  ↓  ↓   ↓  ↓

    0 1  2  3  4  5

    中文字符串也是同样的,一个中文字,即一个索引

    s = 'python是最好的语言'
    s1 = s[7:9]
    print(s1)
    

     全取

    s = 'python是最好的语言'
    s1 = s[:]
    print(s1)
    

     切片会产生新的变量,在内存中,原字符串和切片后的字符串,是2个变量;s4 = s[:]虽然结果是一样的,但它是2个变量,对字符串操作,都会产生新的变量,除了赋值以外。

    取最后5个字符串

    s = 'python是最好的语言'
    s1 = s[-5:]
    print(s1)
    

       步长

    默认步长为1;隔一个取1个,步长为2;反向取值,也就是从后向前取,步长为-1

    隔1个,取一个

    s = 'python是最好的语言'
    s1 = s[::2]
    print(s1)
    

     反向取5个

    s = 'python是最好的语言'
    s1 = s[-5:-1]
    print(s1)
    

     反向全取

    s = 'python是最好的语言'
    s1 = s[::-1]
    print(s1)
    

     字符串常用操作方法

    capitalize() 首字母大写,其他字母小写

    s = 'laoshi'
    s1 = s.capitalize()
    print(s1)
    

     upper() 全部大写

    lower() 全部小写

    s = 'laoshi'
    s1 = s.upper()
    s2 = s.lower()
    print(s1,s2)
    

     比如验证码判断功能

    code = 'aeQu'
    your_code = input('请输入验证码:')
    if your_code.upper() == code.upper():
        print('验证码验证成功')
    

    代码优化一下

    code = 'aeQu'.upper()
    your_code = input('请输入验证码:').upper()
    if your_code == code:
        print('验证码验证成功')
    

     center() 居中

    s = 'laoshi'
    #总宽度为30,并且字符串居中,不足30,默认用空格填充
    s1 = s.center(30)
    #使用*填充
    s2 = s.center(30,'*')
    print(s1)
    print(s2)
    

     如果宽度小于字符串,按照原来的字符串显示

    swapcase() 大小写反转

    s = 'LaoShi'
    s1 = s.swapcase()
    print(s1)
    

     title() 每个单词的首字母大写(非字母隔开)

    s = 'xiao wusir*nanhai'
    s1 = s.title()
    print(s1)
    

     startswith()  判断以什么为开头

    endswith()  以什么结尾

    startswith的start和end参数是切片,如果想取到最后,end参数,不需要指定

    s = 'xiao wusir*nanhai21shui'
    s1 = s.startswith('a')
    s2 = s.endswith('i')
    #切片,取索引访问1~4,再判断是否以i开头
    s3 = s.startswith('i',1,4)
    #切片,取索引范围5~结束,结束位置参数没给,默认一直取到尾
    s4 = s.startswith('w',5)
    print(s1)
    print(s2)
    print(s3)
    print(s4)
    

     strip()  去除首尾的空格,换行符(),tab键(4个空格用 表示)

    s = '
    laoshi	'
    s1 = s.strip()
    print(s1)
    

     如果用户输入的内容不小心包含了空格,也可以验证通过

    name = input('请输入用户名:').strip()
    if name == 'xiao':
        print('ok')
    

     后续操作文件读取一行内容的时候,也会带有换行符,虽然你看不见,使用strip(),就可以去除了

    ✴lstrip() 去除左边的空格、换行符、tab键
    ✴rstrip() 去除右边的空格、换行符、tab键

    strip()还可以去除指定的字符串

    name = 'jingsan123'
    s1 = name.isalnum()
    s2 = name.isalpha()
    s3 = name.isdigit()
    print(s1,s2,s3)
    

     isdigit()比较常用,比如判断用户输入的,是否是数字。

    name = '123a'
    if name.isdigit():
        name = int(name)
    else:
        print('您输入的含有非数字元素')
    

    len() 查看数据的长度

    name = 'zhangsan'
    print(len(name))
    

     二、for循环

    先来使用while循环,打印每一个字符串

    s = 'abcdef'
    count = 0
    while count < len(s):
        print(s[count])
        count += 1
    

     使用for循环完成上面的功能

    s = 'abcdef'
    for i in s:
        print(i)
    

    for循环和while循环的区别在于
    for 循环是有限循环
    while 循环是无限循环 

    有些情况,在不需要终止条件的情况下,使用for循环
    有终止条件的,使用while循环

    for循环会自动停止

    今日作业

    1,有变量name = "aleX leNb" 完成如下操作:
        1)  移除 name 变量对应的值两边的空格,并输出处理结果
        2)  移除name变量左边的'al'并输出处理结果
        3)  移除name变量右面的'Nb',并输出处理结果
        4)  移除name变量开头的a'与最后的'b',并输出处理结果
        5)  判断 name 变量是否以 "al" 开头,并输出结果
        6)  判断name变量是否以"Nb"结尾,并输出结果
        7)  将 name 变量对应的值中的 所有的"l" 替换为 "p",并输出结果
        8)  将name变量对应的值中的第一个'l'替换成'p',并输出结果
        9)  将 name 变量对应的值根据 所有的"l" 分割,并输出结果。
        10) 将name变量对应的值根据第一个'l'分割,并输出结果。
        11) 将 name 变量对应的值变大写,并输出结果
        12) 将 name 变量对应的值变小写,并输出结果
        13) 将name变量对应的值首字母'a'大写,并输出结果
        14) 判断name变量对应的值字母'l'出现几次,并输出结果
        15) 如果判断name变量对应的值前四位'l'出现几次,并输出结果
        16) 从name变量对应的值中找到'N'对应的索引(如果找不到则报错),并输出结果
        17) 从name变量对应的值中找到'N'对应的索引(如果找不到则返回-1)输出结果
        18) 从name变量对应的值中找到'X le'对应的索引,并输出结果
        19) 请输出 name 变量对应的值的第 2 个字符?
        20) 请输出 name 变量对应的值的前 3 个字符?
        21) 请输出 name 变量对应的值的后 2 个字符?
        22) 请输出 name 变量对应的值中 "e" 所在索引位置?
        23)获取子序列,去掉最后一个字符。如: oldboy 则获取 oldbo。
     
    2,有字符串s = '123a4b5c'
        1)通过对li列表的切片形成新的字符串s1,s1 = '123'
        2)通过对li列表的切片形成新的字符串s2,s2 = 'a4b'
        3)通过对li列表的切片形成新的字符串s3,s3 = '1345'
        4)通过对li列表的切片形成字符串s4,s4 = '2ab'
        5)通过对li列表的切片形成字符串s5,s5 = 'c'
        6)通过对li列表的切片形成字符串s6,s6 = 'ba2'
     
    3,使用while和for循环分别打印字符串s='asdfer'中每个元素。
    4,实现一个整数加法计算器(两个数相加):
    如:content = input('请输入内容:')  # 如用户输入:5+9或5+ 9或5 + 9,然后进行分割再进行计算。
    5,计算用户输入的内容中有几个整数(以个位数为单位)。
    如:content = input('请输入内容:')   # 如fhdal234slfh98769fjdla
    
  • 相关阅读:
    【leetcode】21-MergeTwoSortedLists
    【leetcode】20-ValidParentheses
    【c++基础】遍历目录并写入txt文件-linux
    【c++基础】字符数组和string相互转换
    【linux基础】使用命令行编译运行c++程序
    第2章 重新组织函数(4):函数对象、替换算法
    第2章 重新组织函数(3):引入解释性变量、分解临时变量和移除对参数的赋值
    第2章 重新组织函数(2):内联函数、内联临时变量和查询函数
    第2章 重新组织函数(1):提炼函数
    第1章 重构,第一个案例(3):运用多态取代switch
  • 原文地址:https://www.cnblogs.com/Black-rainbow/p/8613060.html
Copyright © 2020-2023  润新知