zoukankan      html  css  js  c++  java
  • Python学习笔记 第四天

    Python学习笔记 第四天

    1 上次作业补充拓展

       1.1 进制转换

              format()

               补充:‘b’二进制 ‘o’八进制 ‘d’十进制

                          ‘x’十六进制

               例:print(format(number,'b'))

               int(string,number)将任意进制的字符转化为十进制

       1.2 类型判断

            type() 查询类型

            isinstance() 判断一个对象是否是一个已知的类型,如若需要判断两个类型是否相同,推荐使用此函数

            isinstance(object,classinfo) classinfo 可以直接是或间接类名,基本类型或者是它们构成的元组

            isinstance()返回一个布尔类型

            raise 显示引发的异常,程序出错时Python自动触发异常,也可以通过raise显示引发的异常。(相当于抛出异常)

           执行raise后,后面的程序不再运行

    2.今日学习内容

        2.1 格式化输出

             %s 字符占位符

             %d 数字占位符

             注意:"%d" 在Python中是不存在的,一般用%%表示字符串中%。但是如果语句中没有%d,%s等占位符,直接写一个%就好。

       2.2 基本运算符

             2.2.1 算术运算 :

                       + - * / %(取余数) //(取整除) **(幂)

            2.2.2 比较运算 :

                     == != <>(不等于) > < >= <=

            2.2.3 赋值运算 :

                     = +=(自增运算) -=(自减运算) *= /=

                    //= %=

                   **=(幂等 a ** = b 等价于 a = a*a*b)

           2.2.4 逻辑运算 :

                    or and not

                   逻辑运算的优先级顺序 :

                   () > not > and >or

      2.3 编码

           2.3.1 存储单位

                    bit 最小的存储单位

                     8 bit = 1 Byte 一字节

                1024 B = 1 KB (KiloByte) 千字节

              1024 KB = 1 MB (MegaByte) 兆字节

             1024 MB = 1 GB (GigaByte) 吉字节

             1024 GB = 1 TB (TeraByte) 太字节

             1024 TB = 1 PB (PetaByte) 拍字节

             1024 PB = 1 EB (ExaByte) 艾字节

             1024 EB = 1 ZB (ZetaByte) 泽字节

             1024 ZB = 1 YB (YottaByte) 尧字节

            1024 YB = 1 BB (Brontobyte) 珀字节

            1024 BB = 1 NB (NonaByte) 诺字节

            1024 NB = 1 DB (DoggaByte) 刀字节

       2.3.2 编码

              ASCII :最多支持256个字符。具体内容请自行百度

             GBK :仅限中国地区使用,每个字符占16位(2字节)

             Unicode :万国码

             UTF-8 :每个字符最少占8位

             UTF-16: 每个字符占16位

       2.4 切片

            2.4.1 切片处理

                    使用下标来获取部分字符串内容

                   print(字符串名[开始位置:结束位置:截取步长]

                  注意:截取顾头不顾尾,设置步长则会进行跳跃式截取

           2.4.2 字符串处理

                    str.capitalize() :字符串首字母大写

                    str.lower() :字符串全部小写

                    str.upper() :字符串全部大写

                    str.title() :字符串每个单词首字母进行大写

                   str.center() :字符串居中处理

                   str.strip() :去除字符串左右两端空格

                   str.lstrip() :去除字符串左边空格

                   str.rstrip() :去掉字符串右边空格

                   str.replace("要被更换的内容","更改的内容")

                    字符串的部分替换

                    str.split("切割标记") :对字符串按标记进行切割

                    注意:字符串的位置不同,导致截取的结果可能也不同(注意缩进)

    s9 = """

    左牵黄

    右擎苍

    锦帽貂裘

    千骑卷平冈

    为报倾城随太守

    亲射虎

    看孙郎

    """

    print(s9.split(" "))

    输出结果:

    ['', '左牵黄', '右擎苍', '锦帽貂裘', '千骑卷平冈', '为报倾城随太守', '亲射虎', '看孙郎', '']

    情况二:

    s9 = """左牵黄

    右擎苍

    锦帽貂裘

    千骑卷平冈

    为报倾城随太守

    亲射虎

    看孙郎"""

    print(s9.split(" "))

    输出结果:

    [ '左牵黄', '右擎苍', '锦帽貂裘', '千骑卷平冈', '为报倾城随太守', '亲射虎', '看孙郎']

    所以需要注意,字符串的位置不同,导致截取的结果可能也不同

    str = "XXX%s,XXX%s"%(内容一,内容二)

    str = "XXX{},XXX{}".format(内容一,内容二)

    注意:如无特别注明,默认按照顺序打印对应内容,不同的出入方式,所打印的结果也可能会有所不同

    例:

    str = "我叫{},今年{}岁了".format("kaka",2)

    str = "我叫{name},今年{age}岁了".format(name ="kaka",age = 2)

    str = "我叫{1},今年{2}岁了".format("kaka",2)

    str.startswith("要判断的文字") :  判断字符串的开头,返回布尔类型

    str.endswith("要判断的文字"):判断字符串的结尾,返回布尔类型

    str.count("要统计的文字"):统计字符串中某字符出现的次数

    str.find("要查找的文字"):查找字符串中的某个字符位置,如果未查询到,返回 -1

    str.find("要查找的文字",开始位置,结束位置):从指定位置查找字符(切片式查找),找到第一个出现的位置。如果未查询到,返回-1

    str.index("要查找的字符"):查找特定字符的位置,如果未查询到,报告错误

    str.isalnum() :判断字符串是否全是字母或数字组成

    str.isalpha() :判断字符串是都全是字母组成       注意:判断时,空格也会被进行判断

    str.isdigit() :判断字符串是否只由数字组成。

    str.islower() :判断字符串是否由小写字母组成。

    str.isnumeric() :判断字符串是否只由数字组成。注意:一、这种方法是只针对unicode对象。二、定义一个字符串为Unicode,只需要在字符串前添加 'u' 前缀即可

    str.isspace() :判断字符串是否只由空格组成

    str. istitle() :判断字符串中所有的单词拼写首字母是否为大写,且其他字母为小写。

    str.isupper():判断字符串中所有的字母是否都为大写

    str.join(要连接的元素序列) :将序列中的元素以指定的字符连接生成一个新的字符串

     

            2.4.3列表处理

                   2.4.3.1 常见操作

    len(对象名):当前字符串长度(内置函数,可直接调用)

    print(list[索引下标])

    print(list[索引下标][元素内字符下标])

    print(list[索引开始下标:索引结束下标:截取步长])

    注意:截取顾头不顾尾,设置步长则会进行跳跃式截取,“-”代表倒取,即从末端位置反向截取

               2.4.3.2 列表的增删改查操作

                             2.4.3.2.1 增 append方法(末端添加)

    例:

    list = []

    while True:

    content = input("请输入您的信息,输入Q退出!!!")

    if content.upper() == 'Q':

    break

    list.append(content)

    print(list)

                         2.4.3.2.2 删

                                       2.4.3.2.2.1 pop方法

                                             注意:pop(指定位置下标),下标若未指明,则默认删除最后一个

                                      2.4.3.2.2.2 del方法(切片式删除)

                                            del[删除开始位置:删除结束位置]

                                      2.4.3.2.3 改(切片式修改)

                                             list[开始下标:结束下标:截取步长]= [对应修改的元素]

                                           注意:截取顾头不顾尾,设置步长则会进行跳跃式截取,“-”代表倒取,即从末端位置反向截取

               2.4.3.3 输出

                                循环输出

                               for item in 列表名:

                                     print(item)

              2.4.3.4 列表的嵌套

    采用降维操作,一层一层的去找,切勿心急

    例:

    list = ["张三","李四","王五","赵六","田七",["CXK","101","Sky","801","183"]]

    print(list[-1][0:2])

    输出结果

    ['CXK', '101']

             2.4.3.5 元组的嵌套

                             元组元素不可修改,但是如果其中嵌套的有列表等可变形式,那么这个可变形式中的元素可以进行修改。

                      换言之,元组的不可变性只针对子元素,如若子元素的内部是可变对象,那么,元组中的子元素的子元素是可变的。

  • 相关阅读:
    【Jsoi2010】连通数
    【CQOI2009】中位数图
    【POJ 1151】 Altlantis
    【2017省中集训】 香港记者
    【AHOI2009】中国象棋
    【SCOI 2009】 Windy数
    【HDU 4722】 Good Numbers
    【HDU 2089】 不要62
    BZOJ3129 SDOI2013方程(容斥原理+扩展lucas)
    BZOJ1042 HAOI2008硬币购物(任意模数NTT+多项式求逆+生成函数/容斥原理+动态规划)
  • 原文地址:https://www.cnblogs.com/tjlhappyboy/p/11209590.html
Copyright © 2011-2022 走看看