python基础(5):格式化输出、基本运算符、编码问题
1. 格式化输出
现在有以下需求,让⽤户输入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%了") # 没有占位符
2. 基本运算符
计算机可以进行的运算有很多种,可不只加减乘除这么简单,运算按种类可分为:
算术运算、比较运算、逻辑运算、赋值运算、成员运算、身份运算、位运算。
这章我们暂只学习算数运算、⽐较运算、逻辑运算、赋值运算
2.1 算术运算
以下假设变量:a=10,b=20

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

2.3 逻辑运算
以下假设变量:a=10,b=20

针对逻辑运算的进⼀步研究:
1.在没有()的情况下not 优先级⾼于 and,and优先级⾼于or,即优先级关系为( )>not>and>or,同⼀优先级从左往 右计算。
() > not > and > or
例题: 判断下列逻辑语句的True,False。
3>4 or 4<3 and 1==1
1 < 2 and 3 < 4 or 1>2
2 > 1 and 3 < 4 or 4 > 5 and 2 < 1
1 > 2 and 3 < 4 or 4 > 5 and 2 > 1 or 9 < 8
1 > 1 and 3 < 4 or 4 > 5 and 2 > 1 and 9 > 8 or 7 < 6
not 2 > 1 and 3 < 4 or 4 > 5 and 2 > 1 and 9 > 8 or 7 < 6
2.
x or y , 如果x是0 返回y, 如果x是非零, 返回x
x and y, 如果x是0 返回x, 如果x是非零, 返回y
not x,如果是0,返回True,如果x是非零, 返回False

例题:求出下列逻辑语句的值。
8 or 4
0 and 3
0 or 4 and 3 or 7 or 9 and 6
2.4 赋值运算
以下假设变量:a=10,b=20

3. 编码的问题
python2解释器在加载 .py⽂件中的代码时,会对内容进⾏编码(默认ascill),⽽python3对内容进⾏编码的默认为utf8。
计算机:
早期,计算机是美国发明的,普及率不⾼,⼀般只是在美国使⽤。所以, 最早的编码结构就是按照美国⼈的习惯来编码的。 对应数字+字⺟+特殊字符⼀共也没多少, 所以就形成了最早的编码ASCII码,直到今天ASCII依然深深的影响着我们。
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。
字⺟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位。
单位转换:
8bit = 1byte
1024byte = 1KB
1024KB = 1MB
1024MB = 1GB
1024GB = 1TB
1024TB = 1PB
1024TB = 1EB
1024EB = 1ZB
1024ZB = 1YB
1024YB = 1NB
1024NB = 1DB
补充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: 不表⽰任何内容,为了代码的完整性,占位⽽已。
补充2: in和not in
可以判断xxx字符串是否出现在xxxxx字符串中
content = input("请输⼊你的评论")
if "苍⽼师" in content or '邱⽼师' in content:
print('你输⼊的内容不合法')
else:
print("评论成功")
python基础(5):格式化输出、基本运算符、编码问题的更多相关文章
- Python基础之格式化输出、运算符、数字与布尔值互换以及while...else
python是一天学一点,就这样零零碎碎…… 格式化输出 %是占位符,%s是字符串格式,%d整数格式,%f是浮点数格式 name = input('输入姓名') age = input('输入年龄') ...
- Python基础篇(格式化输出,运算符,编码):
Python基础篇(格式化输出,运算符,编码): 格式化输出: 格式:print ( " 内容%s" %(变量)) 字符类型: %s 替换字符串 %d 替换整体数字 ...
- python基础_格式化输出(%用法和format用法)(转载)
python基础_格式化输出(%用法和format用法) 目录 %用法 format用法 %用法 1.整数的输出 %o -- oct 八进制%d -- dec 十进制%x -- hex 十六进制 &g ...
- 2.Python基础认识(格式化输出,while语句,运算符,编码,单位转化)
Python基础认识 1.字符串的格式化初识及占位符的简单应用 字符串的格式化 按照既定的要求进行有规定排版的一种输出方式. #我们想要输出的格式如下: ----------------------- ...
- python基础(格式化输出、基本运算符、编码)
1,格式化输出. 现有一练习需求,问用户的姓名.年龄.工作.爱好 ,然后打印成以下格式 ------------ info of Alex Li ----------- Name : Alex Li ...
- Python的格式化输出,基本运算符,编码
一. 格式化输出现在有以下需求,让用户输入name, age, job,hobby 然后输出如下所示: -----------info of Alex Li----------- Name : Ale ...
- Python学习day05 - Python基础(3) 格式化输出和基本运算符
figure:last-child { margin-bottom: 0.5rem; } #write ol, #write ul { position: relative; } img { max- ...
- 319 Python基础之格式化输出、逻辑运算符、编码、in not in、while else、
一.格式化输出 占位符%,字符串占位符%s,数字占位符%d 第一种name = input('姓名') age = input('年龄') hobby = input ("爱好") ...
- python基础_格式化输出(%用法和format用法)
目录 %用法 format用法 %用法 1.整数的输出 %o —— oct 八进制%d —— dec 十进制%x —— hex 十六进制 1 >>> print('%o' % 2 ...
随机推荐
- 《机器学习实战之第二章k-近邻算法》
入坑<机器学习实战>: 本书的第一个机器学习算法是k-近邻算法(kNN),它的工作原理是:存在一个样本数据集合,也称作训练样本集,并且样本集中每个数据都存在标签,即我们知道样本集中每一数据 ...
- Linux系统:centos7下搭建Nginx和FastDFS文件管理中间件
本文源码:GitHub·点这里 || GitEE·点这里 一.FastDFS简介 1.基础概念 FastDFS是一个开源的轻量级分布式文件系统,它对文件进行管理,功能包括:文件存储.文件同步.文件上传 ...
- 【nodejs原理&源码赏析(6)】深度剖析cluster模块源码与node.js多进程(下)
目录 一. 引言 二.server.listen方法 三.cluster._getServer( )方法 四.跨进程通讯工具方法Utils 五.act:queryServer消息 六.轮询调度Roun ...
- Spring Boot + Redis实战-利用自定义注解+分布式锁实现接口幂等性
场景 不管是传统行业还是互联网行业,我们都需要保证大部分操作是幂等性的,简单点说,就是无论用户点击多少次,操作多少遍,产生的结果都是一样的,是唯一的.而今次公司的项目里,又被我遇到了这么一个幂等性的问 ...
- cesium 入门开发系列矢量瓦片加载展示(附源码下载)
前言 cesium 入门开发系列环境知识点了解:cesium api文档介绍,详细介绍 cesium 每个类的函数以及属性等等cesium 在线例子 内容概览 cesium 实现矢量瓦片加载效果 源代 ...
- Saltstack_实战指南02_各主机Pillar信息指定
1. 实战项目GitHub地址 该项目已经放在了GitHub上,地址如下: https://github.com/zhanglianghhh/salt-example-lnmp 2. 主机规划 3. ...
- centos7.6 创建磁盘格式化
fdisk /dev/vdb mkfs.ext4 /dev/vdb echo '/dev/vdb /sdata ext4 defaults 0 0' >> /etc/fstab mount ...
- Jenkins实现单一安卓项目打包多个module填坑实录
今天接手一个任务,已有项目结构上新添加了一个module,这个module打包工作需要在Jenkins上添加一个方便测试点击的打包工程 因为之前已有现成的打包工程,我直接新建了一个工程并且复制原有工程 ...
- 关于网站登录后的页面操作所携带的不同cookie值
对于课堂派网站,登录后的页面操作只需要携带PHPSESSID或者cookie中间那部分即可,两个都带也可,SERVERID不知道是干啥的,每次响应的都会变. 代码实现: cookie = None c ...
- 二叉搜索树中第K小的元素
给定一个二叉搜索树,编写一个函数 kthSmallest 来查找其中第 k 个最小的元素. 说明:你可以假设 k 总是有效的,1 ≤ k ≤ 二叉搜索树元素个数. 示例 1: 输入: root = [ ...