• 万恶之源- 02 运算符和编码


      

    一. 格式化输出

    现在有以下需求,让用户输入name, age, job,hobby 然后输出如下所示:

    ------------ info of Alex Li -----------
    Name : Alex Li
    Age : 22
    job : Teacher
    Hobbie: girl
    ------------- end -----------------
    

      

    你怎么实现呢?你会发现,用字符拼接的方式还难实现这种格式的输出,所以一起来学一下新姿势
    只需要把要打印的格式先准备好, 由于里面的一些信息是需要用户输入的,你没办法预设知道,因此可以先放置个占位
    符,再把字符串串⾥里里的占位符与外部的变量量做个映射关系就好啦

    name = input("Name:")
    age = input("Age:")
    job = input("Job:")
    hobby = input("Hobbie:")
    info = '''
    ------------ info of %s ----------- #这里的每个 %s 就是一个占位符,本行的代表 后面拓拓号里的 name
    Name : %s #代表 name
    Age : %s #代表 age
    job : %s #代表 job
    Hobbie: %s #代表 hobbie
    ------------- end -----------------
    ''' % (name,name,age,job,hobbie) # 这行的 % 号就是 把前面的字符串 与拓号 后面的 变量 关联起来
    print(info)

    %s 就是代表字符串占位符,除此之外,还有 %d, 是数字占位符, 如果把上面的age后⾯面的换成%d,就代表你必须只能输入数字啦
    这时对应的数据必须是int类型. 否则程序会报错
    使用时,需要进行类型转换.

    int(str) # 字符串转换成int
    str(int) # int转换成字符串
    

    类似这样的操作在后面还有很多

    觉着转换很麻烦. 也可以全部都用%s. 因为任何东西都可以直接转换成字符串--> 仅限%s

    现在又来新问题了. 如果想输出:

    我叫xxx, 今年xx岁了,我们已经学习了2%的python基础了

    这里的问题出在哪里呢? 没错2%, 在字符串中如果使用了%s这样的占位符. 那么所有的%都将变成占位符. 我们的2%也变成了占位符.

    而"%的"是不存在的, 这里我们需要使用 %% 来表示字符串中的%.

    注意: 如果你的字符串中没有使用过 %s,%d 站位. 那么不需要考虑这么多. 该%就%.没毛病老铁.

    print("我叫%s, 今年22岁了, 学习python2%%了" % '王尼玛') # 有%占位符
    print("我叫王尼玛, 今年22岁, 已经凉凉了100%了") # 没有占位符

    小总结:

    %s就是代表字符串占位符,任何东西都可以直接转换成字符串--> 仅限%s

    除此之外,还有%d, 是数字占位符,对应的数据必须是int类型,否则程序会报错

    那么所有的%都将变成占位符. 我们的2%也变成了占位符. 而"%的"是不存在的, 这里我们需要使用%%来表示字符串中的%.

    int(str) # 字符串转换成int
    str(int) # int转换成字符串

    二. 基本运算符

    2.1 算数运算
    以下假设变量:a=10,b=20

     

    2.2 比较运算
    以下假设变量:a=10,b=20

     

    赋值运算
    以下假设变量:a=10,b=20

     

    算逻辑运

     

    小总结

    针对逻辑运算的进一步研究:
      1, 在没有()的情况下not 优先级高于 and,and优先级高于or,即优先级关系为( )>not>and>or,同一优先级从左往右计算。
    () > not > and > or

    x or y , x为真,值就是x,x为假,值是y;
    x and y, x为真,值是y,x为假,值是x

    三. 编码的问题
    python3对内容进行编码的默认为utf-8。

    UTF编码.可变长度编码
    UTF-8: 每个字符最少占8位. 每个字符占用的字节数不定.根据文字内容进行具体编码. 比如. 英文. 就一个字节就够了. 汉
    字占3个字节. 这时即满足了中文. 也满足了节约. 也是目前使用频率最高的一种编码
    UTF-16: 每个字符最少占16位.
    GBK: 每个字符占2个字节, 16位.

    单位转换:
    8bit = 1byte
    1024byte = 1KB
    1024KB = 1MB
    1024MB = 1GB
    1024GB = 1TB
    1024TB = 1PB

  • 相关阅读:
    艾伟:几个ASP.NET小技巧 狼人:
    艾伟:.Net架构网站又一传奇:PlentyOfFish.com 狼人:
    艾伟:WCF从理论到实践(3):八号当铺之黑色契约 狼人:
    艾伟:WCF从理论到实践(1):揭开神秘面纱 狼人:
    艾伟:WCF从理论到实践(8):事件广播 狼人:
    艾伟:WCF从理论到实践(4):路在何方 狼人:
    艾伟:WCF从理论到实践(7):消息交换模式 狼人:
    增加联系人到通讯录
    [置顶] 第五周项目一:三角形类(构造函数)@(1)
    5_4学生类
  • 原文地址:https://www.cnblogs.com/zpf666/p/9664811.html
Copyright © 2020-2023  润新知