格式化输出,基本运算符,编码的问题

格式化输入

name = input('Name:')
age = input('Age:')
job = input('Job:')
hobby = input('hobby:')
print('''------------ info of %s -----------
Name : %s
Age : %d
job : %s
Hobbie: %s
------------- end -----------------''' % (name, name, int(age), job, hobby))

s%就是代表字符串占位符,除此之外,还有%d,是数字占位符,如果把上面的age后面的%d,就代表你必须只能输入数字啦.

这时对应的数据必须时int类型,否则程序会报错

int(str)  # 字符串转成int

新的问题来了!如何输出我叫×××,今年×岁了,我们学习了2%的python基础了

print("我叫%s,我学了2%%python基础" %chenrun)

当前面用了s%占位符,当后面再次出现%时python会自动默认这个%时占位符,此时想输出%必须使用两个%%.

基本运算符

计算机可以进行的运算有很多种,可不止加减乘除这么简单运算按种类可分为:

算数运算

比较运算

逻辑运算

赋值运算

成员运算

身份运算

位运算

算术运算

+ , - , * , / , % , ** , //

比较运算

== , != , < , > , <= , >=

赋值运算

= , += , -= , *= , /= , %= , **= , //=

逻辑运算

and   or   not

逻辑运算的优先级: ( ) > not > and > or , 同一优先级从左往右计算

print(0 or 1)  # 1
print(1 or 0)  # 1

print(0 and 1)  # 0
print(1 and 0)  # 0

方便记忆特此发明陈氏记忆法:如果是and,前方为0,输出0,非0弃之选其他.

如果时or,前方为0弃之选其他,非0择优选.

 

编码的问题

python2的解释器在加载.py文件中的代码时,会对内容进行编码(默认为ascii),而python3对内容进行编码的默认为utf-8

 

运算符ASCII(American Standard Code for Information Interchange,美国标准信息交换代码)是基于拉丁字母 的一套电脑编码系统,主要用于显示现代英语和其他西欧语言,其多只能用 8 位来表示(一个字节),即: 2**8 = 256,所以,ASCII码多只能表示 256 个符号。

随着计算机的发展. 以及普及率的提高. 流行到欧洲和亚洲. 这时ASCII码就不合适了. 比如: 中文汉字有几万个. 而 ASCII多也就256个位置. 所以ASCII不行了. 怎么办呢? 这时, 不同的国家就提出了不同的编码用来适用于各自 的语言环境. 比如, 中国的GBK, GB2312, BIG5, ISO-8859-1等等. 这时各个国家都可以使用计算机了.
    GBK, 国标码占用2个字节. 对应ASCII码 GBK直接兼容. 因为计算机底层是用英文写的. 你不支持英文肯定不 行. 而英文已经使用了ASCII码. 所以GBK要兼容ASCII.
    这里GBK国标码. 前面的ASCII码部分. 由于使用两个字节. 所以对于ASCII码而言. 前9位都是0
  国标码的弊端: 只能中国用. 日本就垮了. 所以国标码不满足我们的使用. 这时提出了一个万国码Unicode. unicode一开始设计是每个字符两个字节. 设计完了. 发现我大中国汉字依然无法进行编码. 只能进行扩充. 扩充 成32位也就是4个字节. 这回够了. 但是. 问题来了. 中国字9万多. 而unicode可以表示40多亿. 根本用不了. 太浪 费了. 于是乎, 就提出了新的UTF编码.可变长度编码
UTF-8: 每个字符少占8位. 每个字符占用的字节数不定.根据文字内容进行具体编码. 比如. 英文. 就一个字节就 够了. 汉字占3个字节. 这时即满足了中文. 也满足了节约. 也是目前使用频率高的一种编码
UTF-16: 每个字符少占16位.
GBK: 每个字符占2个字节, 16位.

8bit = 1byte
1024byte = 1KB
1024KB = 1MB
1024MB = 1GB
1024GB = 1TB
1024TB = 1PB
1024TB = 1EB
1024EB = 1ZB
1024ZB = 1YB
1024YB = 1NB
1024NB = 1DB

补充


index = 1
while index < 11:
    if index == 8:
        # break
        pass
    else:
        print(index)
    index = index + 1
else:
    print("你好")

注意:此时while...else为一个整体,当if条件下的break跳出循环时不会执行else下的代码.只有在while条件判断时假的时候才会执行这个else

in 和 not in

content = input("请输入你的评论:")
if "苍老师" in content:
    print("你输入的内容不合法")
else:
    print("评论成功")

 作业:

 猜数游戏

a = 66
count = 0
while True:
    try:
        count += 1
        if count <= 3:
            num_guess = input("输入你猜数字:")
            if int(num_guess) < a:
                print("猜的太小了,请重新输入")
            elif int(num_guess) > a:
                print("猜的太大了,请重新输入")
            elif int(num_guess) == a:
                print("恭喜你猜对了")
                break
        else:
            print("你太笨了...")
            break
    except:
        print("请输入正确的数字")
        pass

写代码,完成下列需求:用户可持续输入(用while循环),用户使用的情况:输入A,则显示走大路回家,然后在让用户进一步选择:是选择公交车,还是步行?

选择公交车,显示10分钟到家,并退出整个程序。选择步行,显示20分钟到家,并退出整个程序。输入B,则显示走小路回家,并退出整个程序。输入C,则显示绕道回家,然后在让用户进一步选择:是选择游戏厅玩会,还是网吧?选择游戏厅,则显示 ‘一个半小时到家,爸爸在家,拿棍等你。’并让其重新输入A,B,C选项。选择网吧,则显示‘两个小时到家,妈妈已做好了战斗准备。’并让其重新输入A,B,C选项。

while True:
    section = input("请输入A,B或C:")
    if section in "A,B,C":
        if section == 'A':
            print("走大路回家")
            section_a = input("选择公交车还是步行>>")
            if section_a == '公交车':
                print("10分钟到家")
                break
            elif section_a == '步行':
                print("20分钟到家")
                break
        elif section == 'B':
            print("走小路回家")
            break
        elif section == 'C':
            print("绕道回家")
            section_c = input("选择游戏厅还是网吧>>")
            if section_c == '游戏厅':
                print("一个半小时到家,爸爸在家,拿棍等你.")
                print("请重新选择")
                continue
            elif section_c == '网吧':
                print("两个小时到家,妈妈已做好了战斗准备.")
                print("请重新输入")
                continue
    else:
        print("请输入正确的选项")

 

 
posted @ 2018-05-31 14:23  猴里吧唧  阅读(95)  评论(0编辑  收藏  举报