while循环 运算符和编码

昨日回顾

1. 初识python
        python是一门弱类型的解释型高级编程语言
        解释器:
            CPython  官方提供的默认解释器. c语言实现的
            PyPy 把python程序一次性进行编译.
            IPython

    2. python的版本
        2.x
        3.x

    3. 变量
        概念: 程序运行过程中产生的中间值. 暂时存储在内存, 方便后面的程序使用它
        就是一个符号.
        x = 10
        郝建 -> 沈腾
        白云 -> 宋丹丹

        命名规范:
            1. 数字, 字母, 下划线组成
            2. 不能是数字开头, 更不能是纯数字
            3. 不能用python的关键字
            4. 不要用中文
            5. 不要太长
            6. 有意义
            7. 区分大小写
            8. 用驼峰或者下划线

        数据类型:
            1. int 整数   +-*/%  //  **
            2. str 字符串,
                把字符连城串
                字符:单一的文字符号
                '', "", ''', """
                + 拼接. 要求两端都得是字符串
                * 重复 必须乘以一个数字
            3. bool 布尔值
                True
                False
                用来判断
        用户交互
            变量 = input(提示语)

        条件判断:
            if 条件:
                if-语句块


            if 条件:
                if-语句块
            else:
                else-语句块


            if 条件1:
                if-1
            elif 条件2:
                if-2
            ......
            else:

今日内容

1. while循环 (难点)
        while 条件:
            循环体(break, continue)

    2. 格式化输出 
     %s 万能
     %d f"{变量}" 3. 运算符 and or not (难点) 运算顺序: ()=> not => and =>or 4. 初识编码 gbk unicode utf-8 1. ascii 8bit 1byte(字节) 256个码位 只用到了7bit, 用到了前128个 最前面的一位是0 2. 中国人自己对计算机编码进行统计. 自己设计. 对ascii进行扩展 ANSI 16bit -> 清华同方 -> gbk GBK 放的是中文编码. 16bit 2byte 兼容ascii 3. 对所有编码进行统一. unicode. 万国码. 32bit. 4byte. 够用了但是很浪费 4. utf-8 可变长度的unicode 英文: 1byte 欧洲文字: 2byte 中文: 3byte 字节(byte) 1byte = 8bit 1kb = 1024byte 1mb = 1024kb 1gb = 1024mb 1tb = 1024gb 1pb = 1024tb 预习: 字符串(记的东西) for循环

while循环

# 语法:
while 条件:
  结果

如果条件是真, 则直接执⾏结果. 然后再次判断条件. 直到条件是假,停⽌循环

那我们怎么终⽌循环呢? 结束循环:

1,改变条件. 2,break

流程控制-break和continue

1, break: 立刻跳出循环. 打断的意思

2, continue: 停⽌本次循环, 继续执⾏下⼀次循环.

while True:
    content = input("请输入你要喷的内容, 输入Q退出")
    if content == "Q":
        # 退出程序 打断循环
        break # 直接跳出循环
    print("你对打野说:", content)



if True:
    print("娃哈哈")


# 最多喷三次
count = 1
while count <= 3:

    # count = 1  # 次数, 死循环
    content = input("请输入你要喷的内容")
    print("你要对上单说:", content)

    # 改变count
    count = count + 1





# continue
while True:
    content = input("请输入你要喷的内容, 输入Q退出")
    if content == "":
        continue # 停止当前本次循环. 继续执行下一次循环  不会彻底终止循环,只是中断不会终止.
    if content == "Q":
        # 退出程序 打断循环
        break # 直接跳出循环
    print("你对打野说:", content)

# 能够让循环退出: 1. break  2. 改变条件

# continue  停止当前本次循环. 继续执行下一次循环
# break  彻底的干掉一个循环




# 让程序从1数数, 数到100
count = 1
while count <= 100:
    print(count) # 1
    count = count + 1


# 计算 1-100之间所有的数的和
sum = 0                 # sum: 0 + 1 + 2 + 3 + 4....99 + 100
count = 1               # count: 1, 2, 3, 4, 99,100, 101
while count <= 100:
    sum = sum + count  # 累加运算
    count = count + 1
print(sum)



# 数数. 1-100奇数
# 方法1
count = 1
while count <= 100:
    print(count)
    count = count + 2

# 方法2
count = 1
while count <= 100:
    if count % 2 == 1:
        print(count)
    else:
        print("偶数....")
    count = count + 1

补充1: while循环. 

while 条件:
    循环体
else: 循环在正常情况跳出之后会执⾏这⾥
# 栗子
index = 1
while index < 11:
    if index == 8:
        # break
pass else:
        print(index)
    index = index+1
else:print("你好")

注意:

如果循环是通过break退出的,那么while后⾯的else将不会被执⾏, 只有在while条件判断是假的时候才会执⾏这个 else.

pass: 不表⽰任何内容,为了代码的完整性,占位⽽已 .

格式化输出

%s 字符串占位符(但是所有的数据类型都可以使用)
%d 数字占位符(只能int类型使用)
f"{变量}"
name = input("请输入你的名字:")
address = input("请输入你来自哪里:")
wife = input("请输入你的老婆:")
notlike = input("请输入你不喜欢的明星:")

print("我叫"+name+", 我来自"+address+", 我老婆是"+wife+", 我不喜欢"+notlike)
# 需要掌握的内容===============
# 格式化输出  %s
print("我叫%s, 我来自%s, 我老婆是%s, 我不喜欢%s" % (name, address, wife, notlike))
# 新版本的格式化输出
print(f"我叫{name}, 我来自{address}, 我老婆是{wife}, 我不喜欢{notlike}")
# 需要掌握的内容===============

hobby = "踢球"
print("我喜欢%s, 我老婆更喜欢%s" % (hobby, hobby))

# %s 表示字符串的占位 . 全能的占位.
print("周杰伦今年%s岁了" % 18)
# %d 占位数字. 只能放数字
print("周杰伦去年%d岁了" % 16)
print("周杰伦去年%d岁了" % "16") # 报错

# 坑, 如果这句话使用了格式化输出. % 就是占位, 如果想显示正常的%   %% 转义
print("我叫%s, 我已经度过了30%的人生了" % "俞洪敏") # 报错 not enough arguments for format string
print("我叫%s, 我已经度过了30%%的人生了" % "俞洪敏")
注意:
  在字符串中如果使⽤了%s这样的占位符,那么所有的%都将变成占位符,我们需要使用%%来表示字符串中的%.

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

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

运算符

什么是运算符?举个简单的例子 4 +5 = 9 。 例子中,4 和 5 被称为操作数,"+" 称为运算符。

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

算数运算、 比较运算、逻辑运算、 赋值运算、

成员运算、 身份运算、 位运算.

算数运算

以下假设变量:a=10,b=20

 

注意: 

// 取整除 - 向下取接近除数的整数
>>> 9//2
4
>>> -9//2
-5

比较运算

以下假设变量:a=10,b=2

# 注意:
print(3 <> 3)  2.x可以使用, 3.x 不能
print(3 > = 3) # 报错,>= 是个整体,不能分开

赋值运算

以下假设变量:a=10,b=20

逻辑运算(重点难点)

 

1,  优先级关系为   () > not > and > or 

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

    x and y,  x为真,值是y,  x为假,值是x。 

#逻辑运算符 初级
'''
and : 并且. 左右两端同时为真. 结果才能是真
or : 或者. 左右两端有一个是真. 结果就是真
not : 非. 非真即假, 非假即真  不真-> 假  不假 -> 真
混合运算顺序: () => not => and => or  当出现相同的优先级的时候 从左往右算

'''
print(3 > 2 and 4 < 6 and 5 > 7) # False
print(5 < 6 or 7 > 8 or 9 < 6 or 3 > 2)  # True
print(not 5 < 6)  # False
print(3 > 2 or 5 < 7 and 6 > 8 or 7 < 5)  # True
print(3 > 4 or 4 < 3 and 1 == 1)  # False
print(1 < 2 and 3 < 4 or 1 > 2)  # True
print(2 > 1 and 3 < 4 or 4 > 5 and 2 < 1) # True
print(1 > 2 and 3 < 4 or 4 > 5 and 2 > 1 or 9 < 8) # False
print(1 > 1 and 3 < 4 or 4 > 5 and 2 > 1 and 9 > 8 or 7 < 6) # False
print((not 2 > 1 and 3 < 4) or 4 > 5 and 2 > 1 and 9 > 8 or 7 < 6) # False


#逻辑运算符 进阶
'''
优先级依然是:() > not > and > or
当出现 x or y的时候, 判断x是否是0 如果x==0 then y 否则返回x
当出现 x and y 的时候, 和or相反(or 要非0,and要0)
把False 当成0,True 当成1来看
'''
# 当出现 x or y的时候, 判断x是否是0 如果x==0 then y 否则返回x
print(1 or 2) # 1
print(0 or 2) # 2
print(3 or 0) # 3
print(4 or 0) # 4
print(0 or 3 or 0 or 2 or 0 or 5 or 0 or 188)  # 3

# 当出现 x and y 的时候, 和or相反
print(1 and 2) # 2
print(0 and 3) # 0
print(3 and 0) # 0
print(4 and 0) # 0
print(9 and 3 and 4 and 1 and 4 and 8)  # 8
print(1 and 2 or 3) # 应付面试  2
print(1 and 2 > 4)  # False

# False 当成0来看
print(False and 1)  # False
print(3 > 5 or 5 < 6 and 7)  # 7
print(4 > 5 or 7 and 8 < 6 or 3 and 4)  # 4
print(4>5 or (7 and 8<6) or (3 and 4)) #优先级顺序依旧存在  4

成员运算

# 成员运算 in
# 栗子1
content = input("请输入你的评论:")
if "马化腾" in content: # content中是否包含了xxx
    print("你的评论不合法")
else:
    print("你的评论是合法的")
# 栗子2
ad = input("请输入你的广告:")
if "" in ad or "第一" in ad or "全球" in ad:
    print("不合法的")

else:
    print("合法的")

  

补充2:

in和not in 可以判断xxx字符串是否出现在xxxxx字符串中 

content = input("请输⼊你的评论")
if "苍⽼师" in content or '邱⽼师' in content:
    print('你输⼊的内容不合法') 
else:
    print("评论成功")

身份运算

身份运算符用于比较两个对象的存储单元

注: id() 函数用于获取对象内存地址。

is 与 == 区别:

is 用于判断两个变量引用对象是否为同一个, == 用于判断引用变量的值是否相等。

>>>a = [1, 2, 3]
>>> b = a
>>> b is a 
True
>>> b == a
True
>>> b = a[:]
>>> b is a
False
>>> b == a
True

位运算

按位运算符是把数字看作二进制来进行计算的。Python中的按位运算法则如下:

下表中变量 a 为 60,b 为 13二进制格式如下:

a = 0011 1100

b = 0000 1101

-----------------

a&b = 0000 1100

a|b = 0011 1101

a^b = 0011 0001

~a  = 1100 0011

a = 60            # 60 = 0011 1100 
b = 13            # 13 = 0000 1101 
c = 0
 
c = a & b;        # 12 = 0000 1100
print ("1 - c 的值为:", c)
 
c = a | b;        # 61 = 0011 1101 
print ("2 - c 的值为:", c)
 
c = a ^ b;        # 49 = 0011 0001
print ("3 - c 的值为:", c)
 
c = ~a;           # -61 = 1100 0011
print ("4 - c 的值为:", c)
 
c = a << 2;       # 240 = 1111 0000
print ("5 - c 的值为:", c)
 
c = a >> 2;       # 15 = 0000 1111
print ("6 - c 的值为:", c)


# 以上实例输出结果:
1 - c 的值为: 12
2 - c 的值为: 61
3 - c 的值为: 49
4 - c 的值为: -61
5 - c 的值为: 240
6 - c 的值为: 15

结果小技巧:

取反:  ~  ==>  ~n  ==>  -(n+1)

左移:<<  ==> a<<b ==> a * 2b

右移:>>  ==> a>>b ==> a // 2b

初识编码

python2解释器在加载 .py ⽂件中的代码时,会对内容进⾏编码(默认ascill),⽽python3对内容进⾏编码的默认为utf- 8。

计算机:

早期. 计算机是美国发明的. 普及率不不高, ⼀般只是在美国使用. 所以. 最早的编码结构就是按照美国人的习惯来编码 的. 对应数字+字母+特殊字符⼀共也没多少. 所以就形成了了最早的编码ASCII码. 直到今天ASCII依然深深的影响着我们.

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

随着计算机的发展. 以及普及率的提高. 流⾏到欧洲和亚洲. 这时ASCII码就不合适了. ⽐如: 中⽂汉字有⼏万个. ⽽ASCII 最多也就256个位置. 所以ASCII不行了. 怎么办呢? 这时, 不同的国家就提出了不同的编码用来适用于各自的语⾔环境. ⽐如, 中国的GBK, GB2312, BIG5, ISO-8859-1等等. 这时各个国家都可以使⽤计算机了.

GBK, 国标码占用2个字节. 对应ASCII码 GBK直接兼容. 因为计算机底层是用英文写的. 你不⽀持英文肯定不行. ⽽英文已经使用了了ASCII码. 所以GBK要兼容ASCII.

这⾥GBK国标码. 前⾯的ASCII码部分. 由于使用两个字节. 所以对于ASCII码而言. 前9位都是0 (因为原来8位的ASCII 码中的最高位是0,留作扩展使用的)

字母A:0100 0001 # ASCII 
字母A:0000 0000 0100 0001 # 国标码

国标码的弊端: 只能中国用. ⽇本就垮了. 所以国标码不满足我们的使用. 这时提出了一个万国码Unicode. unicode一 开始设计是每个字符两个字节. 设计完了. 发现我大中国汉字依然无法进行编码. 只能进行扩充. 扩充成32位也就是4个字 节. 这回够了. 但是. 问题来了. 中国字9万多. 而unicode可以表示40多亿. 根本用不了. 太浪费了. 于是乎, 就提出了了新的 UTF编码.可变⻓度编码

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

UTF-16: 每个字符最少占16位.

GBK: 每个字符占2个字节, 16位. 

小结:(上面是发展历史,我们记住结论就行啦)

# 初识编码   ascii ==> gbk ==> unicode ==> utf-8
    1. ascii   8bit  1byte(字节)  256个码位 只用到了7bit, 用到了前128个 最前面的一位是0
    2. 中国人自己对计算机编码进行统计. 自己设计. 对ascii进行扩展 ANSI 16bit -> 清华同方 -> gbk
        GBK 放的是中文编码. 16bit  2byte 兼容ascii
    3. 对所有编码进行统一. unicode. 万国码.  32bit. 4byte. 够用了但是很浪费

    4. utf-8 可变长度的unicode
        英文: 1byte
        欧洲文字: 2byte
        中文: 3byte

 单位转换

8bit = 1byte 
1024byte = 1KB 
1024KB = 1MB 
1024MB = 1GB 
1024GB = 1TB 
1024TB = 1PB 
1024PB = 1EB 
1024EB = 1ZB 
1024ZB = 1YB 
1024YB = 1NB
1024NB = 1DB
常用到TB就够了

 今日作业及明日默写

 今日作业及明日默写

原文地址:https://www.cnblogs.com/lyfstorm/p/11042024.html