专栏首页python3python3--变量,布尔值,用户交互 input,if语句,while循环

python3--变量,布尔值,用户交互 input,if语句,while循环

python基础初识

运行python代码

print('hello world')

已经运行了第一个python程序,即:终端---->cmd----->python 文件路劲。回车搞定~

内容编码

python2解释器在加载.py文件中的代码时,会对内容进行编码(默认ascill)

而python3对内容进行编码的默认为utf-8

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

显然ASCII码无法将世界上的各种文字和符号全部表示,所以,就需要新出一种可以代表所以字符和符号的编码,即:Unicode

Unicode(统一码,万国码,单一码)是一种在计算机上使用的字符编码。Unicode是为了解决传统的字符编码方案而产生的,它为每种语言中的每个字符设定了统一并且唯一的二进制编码,规定虽有的字符和符号最少由16位来表示(2个字节),即:2**16==65536

注:此处说的是最少2个字节,可能更多

UTF-8,是对Unicode编码的压缩和优化,他不再使用最少使用2个字节,而是将所有的字符和符号进行分类:

ascii码中的内容用1个字节保存,欧洲的字符用2个字节保存,东亚的字符用3个字节保存...

注释

单行注释:#被注释内容

多行注释:'''被注释内容''',或者"""被注释内容"""

变量

变量是什么?变量:把程序运行的中间结果临时的存在内存里,以便后续的代码调用

声明变量

name = 'sam'

上述代码声明了一个变量,变量名为:name,变量name的值为:'sam'

变量的作用:昵称,其代指内存里某个地址中保存的内容

变量定义的规则

变量名只能是字母,数字或下划线的任意组合

变量名的第一个字符不能是数字

以下关键字不能声明为变量名

['and', 'as', 'assert', 'break', 'class', 'continue', 'def', 'del', 'elif', 'else', 'except', 'exec', 'finally', 'for', 'from', 'global', 'if', 'import', 'in', 'is', 'lambda', 'not', 'or', 'pass', 'print', 'raise', 'return', 'try', 'while', 'with', 'yield']

变量的定义要具有可描述性。

推荐定义方式

#驼峰体

UserName = 'sam'

PassWord = 123

#下划线

user_name = 'sam'

number_of_students = 100

推荐使用下划线的方式定义变量名

变量的赋值

name1 = 'zhangsan'

name2 = 'lisi'

例子2

name1 = 'zhangsan'

name2 = name1

定义变量不好的方式举例

变量名为中文,拼音

变量名过长

变量名词不达意

常量

常量即指不变的量,或在程序运行过程中不会改变的量

举例,年龄会变,那这就是变量,但在一些情况下,他的年龄不会变了,那就是常量。在python中没有一个专门的语法代表常量,程序员约定俗用变量名全部大写代表常量

USERNAME = 'sam'

程序交互

#将用户输入的内容赋值给name变量

name = input("输入用户名:")

#打印输入的内容

print(name)

执行脚本就会发现,程序会等待你输入姓名后往下继续走

可以让用户输入多个信息,如下

name = input("你的名字?")

age = input("你的年龄?")

hometown = input("你的家乡?")

print("你好!",name,"今年",age,"来自",hometown)

基础数据类型(初始)

什么是数据类型?

我们可以很容易的分清数字与字符的区别,但是计算机并不能,计算机虽然很强大,但从某种角度上看又很傻,除非你明确的告诉它,1是数字,“汗”是文字,否则它是分不清楚1和“汗”的区别,因此,在每个编程语言里都会有一个叫数据类型的东西,其实就是对常用的各种数据类型进行了明确的划分,你想让计算机进行数值运算,你就传给它数字,你想让它处理文字,就传字符串类型给它

python常用的数据类型有多种,今天只讲3种,数字,字符串,布尔类型

整数类型(int)

int(整型),即数字

long(长整型)

自从python2.2起,如果整数发生溢出,python会自动将整数转换为长整数

在python3里不再有long类型了,全部是int

除了int和long之外,其实还有float浮点,复数型

字符串类型(str)

在python中,加了引号的字符都被认为是字符串!

name = "sam" #双引号

age = '22'        #只要加引号就是字符串

age = 22          #int

msg = '''my name is sam, I am 22 years old!'''    #3个引号也可以

hometown = 'shandong'   #单引号也可以

那单引号,双引号,多引号有什么区别呢?单双引号木有任何区别,只有下面这种情况你需要考虑单双的配合

msg = "my name is sam, I'm 22 years old!"

多引号什么作用呢?作用就是多行字符串必须用多引号

msg = '''

床前明月光,

疑是地上霜,

举头望明月,

低头思故乡。

'''

print(msg)

字符串拼接

数字可以进行加减乘除等运算,字符串呢?也能,但只能进行“相加”和“相乘”运算。

name = 'sam'

age = '22'

name + age #相加其实就是简单拼接

结果:'sam22'

name * 10 #相乘其实就是复制自己多少次,再拼接一起

'samsamsamsamsamsamsamsamsamsam'

注意,字符串的拼接只能是双方都是字符串,不能跟数字或其它类型拼接

布尔值(True,False)

布尔类型很简单,就两个值,一个True(真),一个False(假),主要用逻辑判断

举例,现在有两个值,a=3,b=5,我说a>b,你说成立吗?我们当然知道不成立,但问题是计算机怎么去描述这不成立呢?或者说a<b是成立,计算机怎么描述这是成立呢?

没错,答案就是,用布尔类型

a=3

b=5

a > b #不成立就是False,即假

False

a < b #成立就是True,即真

True

格式化输出

现有一练习需求,问用户的姓名,年龄,工作,爱好,然后打印成以下格式

---------info of sam----------

Name     : sam

Age        : 22

Job         : Teacher

Hobbie  : girl

-------------end--------------

你怎么实现呢?你会发现,用字符拼接的方式很难实现这种格式化的输出,所以来学一下新方法

只需要把要打印的格式先准备好,由于里面的一些信息是需要用户输入的,你没办法预先知道,因此可以先放置个占位符,再把字符串里的占位符与外部的变量做个映射关系就好了

#!/usr/bin/env python
#coding: utf-8
__author__ = 'www.py3study.com'
name = input("Name : ")
age = input("Age : ")
job = input("Job : ")
hobbie = input("Hobbie : ")

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

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

问题:现在有这么行代码

msg = "我是%s,年龄%d,目前学习进度为80%" % ('张三',18)

print(msg)

这样会报错的,因为在格式化输出里,出现%默认为就是占位符的%,但是我想在上面一条语句中最后的80%就是表示80%而不是占位符,怎么办?

方法一

msg = "我是%s,年龄%d,目前学习进度为80%%" % ('张三',18)

print(msg)

这样就可以了,第一个%是对第二个%的转义,告诉python解释器这只是一个单纯的%,而不是占位符。

方法二

msg = "我是{},年龄{},目前学习进度为80%".format('张三',18)

print(msg)

基本运算符

运算符

计算机可以进行的运算有很多种,可不只加减乘除这么简单,运算按种类可分为算数运算,比较运算,逻辑运算,赋值运算,成员运算,身份运算,位运算,今天只学习算数运算,比较运算,逻辑运算,赋值运算

算数运算

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

比较运算

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

赋值运算

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

逻辑运算

针对逻辑运算的进一步研究

1.在没有()括号的情况下not优先级高于and,and优先级高于or,即优先级关系为

()>not>and>or,同一优先级从左往右计算

例题:

判断下列逻辑语句的True,False

>>> 3>4 or 4<3 and 1==1

False

>>> 1<2 and 3

True

>>> 2>1 and 3

True

>>> 1>2 and 3

False

>>> 1>1 and 3

False

>>> not 2>1 and 3

False

>>>

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

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

例题:求出下列逻辑语句的值

>>> 8 or 4

8

>>> 0 and 3

0

>>> 0 or 4 and 3 or 7 or 9 and 6

3

>>> 

in, not in:

判断子元素是否在原字符串(字典,列表,集合)中

例如

>>> print('喜欢' in 'abcd喜欢abcd')

True

>>> print('a' in 'bcdef')

False

>>> print('y' not in 'abcdefg')

True

>>>

流程控制之--if

假如把写程序比做走路,那我们到现在为止,一直走的都是直路,还没遇到过分叉口,想象现实中,你遇到了分叉口,然后你决定往哪走必然是有所机动的。你要判断那条岔路是不是你要走的路,如果我们想让程序也能处理这样的判断怎么办?很简单,只需要在程序里预设一些条件判断语句,满足哪个条件,就走哪条岔路,这个过程就叫流程控制。

if...else 语句

单分支

if 条件:

    满足条件后要执行的代码

双分支

if 条件:

    满足条件执行代码

else:

    if条件不满足就走这段

age = 48

if age > 50:

    print('上了年纪!')

else:

    print('还很年轻!')

缩进

这里必须要插入这个缩进的知识点

你会发现,上面的if代码里,每个条件的下一行都缩进了4个空格,这是为什么呢?这就是python的一大特色,强制缩进,目的是为了程序知道,每段代码依赖哪个条件,如果不通过缩进来区分,程序怎么会知道,当你的条件成立后,去执行哪些代码呢?

在其它的语言里,大多通过{}来确定代码块,比如C,C++,Java,Javascript都是这样,在有{}来区分代码块的情况下,缩进的作用就只剩下让代码变得整洁了

python是门超级简洁的语言,发明者定是觉得用{}太丑了,所以索性直接不用它,那怎么能区分代码块呢?答案就是强制缩进

python的缩进有以下几个原则:

1.顶级代码必须顶行写,即如果一行代码本身不依赖于任何条件,那它必须不能进行任何缩进

2.同一级别的代码,缩进必须一致

3.官方建议缩进用4个空格,当然你也可以用2个,如果你不想被人笑话的话!

多分支

回到流程控制上来,if...else...可以有多个分支条件

if 条件:

    满足条件执行的代码

elif 条件:

    上面的条件不满足就走这个

elif 条件:

    上面的条件不满足就走这个

elif 条件:

    上面的条件不满足就走这个

else:

    上面所有的条件不满足就走这段

写个猜年龄的游戏吧

age = 48
guess = int(input(">>:"))
if guess > age:
    print("猜的太大了,往小里试试...")
elif guess < age:
    print("猜的太小了,往大里试试...")
else:
    print("恭喜你,猜对了...")

上面的例子,根据你输入的值不同,会最多得到3种不同的结果

再来个匹配成绩的小程序吧,成绩有ABCDE 5个等级,与分数的对应关系如下

A 90-100

B 80-89

C 60-79

D 40-59

E 0-39

要求用户输入0-100的数字后,你能正确打印他的对应成绩

score = int(input("输入分数:"))
if score > 100:
    print("最高才100分...")
elif score >= 90:
    print("A")
elif score >= 80:
    print('B')
elif score >= 60:
    print("C")
elif score >= 40:
    print("D")
else:
    print("太笨了...")

这里有个问题,就是当我输入95的时候,它打印的结果是A,但是95明明大于第二个条件elif score >=80:这里为什么不打印B呢?这是因为代码是从上到下依次判断,只要满足一个,就不会再往下走了,这一点一定要记住!

流程控制之--while循环

基本循环

while 条件:

    #循环体

    #如果条件为真,那么循环体则执行

    #如果条件为假,那么循环体不执行

循环终止语句

如果在循环的过程中,因为某些原因,你不想继续循环了,怎么把它终止掉呢?这就用到break或continue语句

break用于完全结束一个循环,跳出循环体执行循环后面的语句

continue和break有点类似,区别在于continue只是终止本次循环,接着还执行后面的循环,break则完全终止循环

例子:break

count = 0
while count <= 100: #只要count<=100就不断执行下面的代码
    print("loop",count)
    if count == 5:
        break
    count +=1 #每执行一次,就把count+1,要不然就变成死循环了,因为count一直是0
print('---out of while loop---')

输出

例子:continue

count = 0
while count  5 and count <95: #只要count在6-9之间,就不走下面的print语句,直接进入下一次loop
        continue
    print("loop", count)
print("---out of while loop---")

输出

while...else...

与其它语言else一般只与if搭配不同,在python中还有个while...else语句

while后面的else作用是指,当while循环正常执行完,中间没有被break终止的话,就会执行else后面的语句

count = 0
while count <= 5:
    count += 1
    print("loop",count)
else:
    print("循环正常执行完啦")
print("---out of while loop---")

输出

如果执行过程中被break了,就不会执行else语句啦

count = 0
while count <= 5:
    count += 1
    if count == 3 :break
    print("loop",count)
else:
    print("循环正常执行完啦!")
print("---out of while loop---")

输出

相关练习

1、使用while循环输入 1 2 3 4 5 6     8 9 10

#!/usr/bin/env python
# coding: utf-8
__author__ = 'www.py3study.com'
content = 0
while content < 10 :
    content += 1
    if content == 7:
        continue
    print(str(content) + ' ', end='')

2、求1-100的所有数的和

#!/usr/bin/env python
# coding: utf-8
# __author__ = 'www.py3study.com'
#方法1
content = 0
for i in range(1,101):
    content += i
print(content)

#方法2
content = 0
sum1 = 0
while content < 100:
    content += 1
    sum1 += content
print(sum1)

3、输出 1-100 内的所有奇数

#!/usr/bin/env python
# coding: utf-8
__author__ = 'www.py3study.com'
#方法1
content = 0
while content < 100:
    content += 1
    if content % 2  == 1:
         print(str(content) + ' ', end='')
    else:
         pass

#方法2
for i in range(1,100):
    if i % 2 == 1:
        print(str(i) + ' ', end='')
    else:
        pass

4、输出 1-100 内的所有偶数

#!/usr/bin/env python
# coding: utf-8
__author__ = 'www.py3study.com'
#方法1
content = 0
while content < 100:
    content += 1
    if content % 2  == 0:
         print(str(content) + ' ', end='')
    else:
         pass
    
#方法2
for i in range(1,100):
    if i % 2 == 0:
        print(str(i) + ' ', end='')
    else:
        pass

5、求1-2+3-4+5 ... 99的所有数的和

#!/usr/bin/env python
# coding: utf-8
__author__ = 'www.py3study.com'
#方法1
count = 0
sum1 = 0
while count < 99:
    count += 1
    if count % 2 == 1:
        sum1 += count
    else:
        sum1 -= count
print(sum1)

#方法2
sum2 = 0
for i in range(1,100):
    if i % 2 == 1:
        sum2 += i
    else:
        sum2 -= i
print(sum2)

6、用户登陆(三次机会重试)

#!/usr/bin/env python
# coding: utf-8
__author__ = 'www.py3study.com'
username = 'Sam'
password = 123456
number = 0
while number < 3:
    number += 1
    username_temporary = input('输入账号:')
    password_temporary = int(input('输入密码'))
    if username_temporary == username and password_temporary == password :
        print('登录成功')
        break
    else:
        print('账户名或密码错误!')
    print("你还有{}次机会".format(3-int(number)))

7、等待用户输入内容,检测用户输入内容中是否包含敏感字符?如果存在敏感字符提示“存在敏感字符请重新输入”,并允许用户重新输入并打印。敏感字符:"小粉嫩"、"大铁锤"

#!/usr/bin/env python
# coding: utf-8
__author__ = 'www.py3study.com'
keyword = ["小粉嫩","大铁锤"]
while True:
    comment = input('请输入评论:')
    for filter_word in keyword:
        if filter_word in comment:
            print('评论含有敏感词,请重新输入!')
            break
    else:
        print('提交成功!')
        break

8、写代码:计算 1 - 2 + 3 ... + 99 中除了88以外所有数的总和?

#!/usr/bin/env python
# coding: utf-8
__author__ = 'www.py3study.com'
count = 0
the_sum = 0
while count < 99:
    count += 1
    if count == 88:
        continue
    if (count % 2) == 0:
        the_sum -= count
    else:
        the_sum += count
 
print(the_sum)

9、制作趣味模板程序需求:等待用户输入名字、地点、爱好,根据用户的名字和爱好进行任意现实 如:敬爱可亲的xxx,最喜欢在xxx地方干xxx

#!/usr/bin/env python
# coding: utf-8
__author__ = 'www.py3study.com'
name = input('请输入你的姓名:')
addres = input('请输入你的地点:')
hobby = input('请输入你的爱好:')
msg = '''
敬爱可亲的{}
最喜欢在{}
地方干{}
'''.format(name,addres,hobby)
print(msg)

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • python - one day

    2008 年出现 python 2.7 与 python 3.0 两个版本,后来 吉多·范罗苏姆 大叔决定停用 python 2.7,但因用户反对,于是决定于 ...

    py3study
  • python3--基础综合练习题

    允许用户最多尝试3次,3次都没猜对的话,就直接退出,如果猜对了,打印恭喜信息并退出

    py3study
  • 循环结构while

    Note: 高能:语句结构都是由关键字开头,用冒号结束!     一:语句结构     while 判断条件:             语句 二:基本...

    py3study
  • python - one day

    2008 年出现 python 2.7 与 python 3.0 两个版本,后来 吉多·范罗苏姆 大叔决定停用 python 2.7,但因用户反对,于是决定于 ...

    py3study
  • 循环 | 这篇文章,我循环看了很久...

    潘永斌
  • python之if循环

    if 条件:   if语句块 elif 条件:   语句块 .... else:   else语句块 #if...elif...else 有一...

    py3study
  • Python基础——判断和循环

    py3study
  • 颤技术之巅—WE ARE TEG

    邀您感受腾讯产品背后的技术力量。WE ARE TEG,you can't see,can feel! ? ? ?

    腾讯大讲堂
  • Python3.x和Python2.x的区别

    http://www.cnblogs.com/codingmylife/archive/2010/06/06/1752807.html

    bear_fish
  • Dart常用的数据类型

    任我行RQ

扫码关注云+社区

领取腾讯云代金券