基础二(格式化字符串、运算符和编码)_day02

一、Python的输出

(1)纯输出一个字符串或数字

print("Hello World")  #输出 Hello World
print(34) #输出 34

(2)利用字符串连接符号(+)输出

name = input("请输入你的名字") #提示用户输入名字
print("您的名字是:"+name)

用字符串拼接就很麻烦了,所以就有了格式化字符串输出

(3)格式化字符串输出

 1 #!/usr/bin/env python
 2 # -*- coding=utf-8 -*-
 3 name = input("Name:")
 4 age = input("Age:")
 5 job = input("Job:")
 6 hobby = input("Hobbie:")
 7 info = ‘‘‘
 8 ------------ info of %s -----------
 9 name: %s
10 Age : %s
11 job : %s
12 Hobbie: %s
13 ------------- end -----------------
14 ‘‘‘ % (name,name,age,job,hobby)
15 #这里的每个%s就是一个占位符,本行的代表 后面拓号里的 name Name : %s #代表 name
16 print(info)

%s代表的就是字符串占位符,%s几乎是万能的

%d代表的数字占位符

如果你想把上面代码中的age转化为int类型,你需要使用

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

(4)如果想输出:

问题:在2%,在字符串中如果使用了%s这样的占位符,那么所有的%都会变成占位符,2%也会变成占位符,这里我们需要用“%%”来表示字符串中的“%”。

注意:如果字符串中没有使用过%s或者%d占位,那么不需要考虑那么多,只需要一个%就可以输出

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

二、基本运算符

基本分类

  • 算术运算符
  • 比较运算符
  • 逻辑运算符
  • 赋值运算符
  • 成员运算符
  • 身份运算符
  • 位运算

在这着重解释前四个

2.1 算术运算符

2.2 比较运算符

2.3 赋值运算符

2.4 逻辑运算符

补充:

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

  () > not > and > or

(2)x or y,x为真,值就是x,x为假,值是y:

  and与or相反

三、编码的问题

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

计算机:

 早期,计算机是美国发明的,普及率不高,一般只是在美国使用。所以,最早的编码结构就是按照美国人的习惯来编码的,形成了最早的ASCII码,直到今天ASCII码依然深深影响着我们。

一、什么是字符编码。

要彻底解决字符编码的问题就不能不去了解到底什么是字符编码。计算机从本质上来说只认识二进制中的0和1,可以说任何数据在计算机中实际的物理表现形式也就是0和1,如果你将硬盘拆开,你是看不到所谓的数字0和1的,你能看到的只是一块光滑闪亮的磁盘,如果你用足够大的放大镜你就能看到磁盘的表面有着无数的凹凸不平的元件,凹下去的代表0,突出的代表1,这就是计算机用来表现二进制的方式。

1.ASCII

现在我们面临了第一个问题:如何让人类语言,比如英文被计算机理解?我们以英文为例,英文中有英文字母(大小写)、标点符号、特殊符号。如果我们将这些字母与符号给予固定的编号,然后将这些编号转变为二进制,那么计算机明显就能够正确读取这些符号,同时通过这些编号,计算机也能够将二进制转化为编号对应的字符再显示给人类去阅读。由此产生了我们最熟知的ASCII码。ASCII 码使用指定的7 位或8 位二进制数组合来表示128 或256 种可能的字符。这样在大部分情况下,英文与二进制的转换就变得容易多了。

2.GB2312

然而,虽然计算机是美国人发明的,但是全世界的人都在使用计算机。现在出现了另一个问题:如何让中文被计算机理解?这下麻烦了,中文不像拉丁语系是由固定的字母排列组成的。ASCII 码显然没办法解决这个问题,为了解决这个问题中国国家标准总局1980年发布《信息交换用汉字编码字符集》提出了GB2312编码,用于解决汉字处理的问题。1995年又颁布了《汉字编码扩展规范》(GBK)。GBK与GB 2312—1980国家标准所对应的内码标准兼容,同时在字汇一级支持ISO/IEC10646—1和GB 13000—1的全部中、日、韩(CJK)汉字,共计20902字。这样我们就解决了计算机处理汉字的问题了。

3.Unicode

现在英文和中文问题被解决了,但新的问题又出现了。全球有那么多的国家不仅有英文、中文还有阿拉伯语、西班牙语、日语、韩语等等。难不成每种语言都做一种编码?基于这种情况一种新的编码诞生了:Unicode。Unicode又被称为统一码、万国码;它为每种语言中的每个字符设定了统一并且唯一的二进制编码,以满足跨语言、跨平台进行文本转换、处理的要求。Unicode支持欧洲、非洲、中东、亚洲(包括统一标准的东亚象形汉字和韩国表音文字)。这样不管你使用的是英文或者中文,日语或者韩语,在Unicode编码中都有收录,且对应唯一的二进制编码。这样大家都开心了,只要大家都用Unicode编码,那就不存在这些转码的问题了,什么样的字符都能够解析了。

4.UTF-8

但是,由于Unicode收录了更多的字符,可想而知它的解析效率相比ASCII码和GB2312的速度要大大降低,而且由Unicode通过增加一个高字节对ISO Latin-1字符集进行扩展,当这些高字节位为0时,低字节就是ISO Latin-1字符。对可以用ASCII表示的字符使用Unicode并不高效,因为Unicode比ASCII占用大一倍的空间,而对ASCII来说高字节的0对他毫无用处。为了解决这个问题,就出现了一些中间格式的字符集,他们被称为通用转换格式,即UTF(Unicode Transformation Format)。而我们最常用的UTF-8就是这些转换格式中的一种。在这里我们不去研究UTF-8到底是如何提高效率的,你只需要知道他们之间的关系即可。

总结:

**1.为了处理英文字符,产生了ASCII码。

2.为了处理中文字符,产生了GB2312。

3.为了处理各国字符,产生了Unicode。

4.为了提高Unicode存储和传输性能,产生了UTF-8,它是Unicode的一种实现形式。**

  ASCII: 8bit 1byte
    GBK: 16bit 2byte
    unicode:32bit 4byte
    UTF-8: 最少8bit, 1byte, 中文: 24bit 3byte
    
    计算机存储系统单位换算
    8bit => 1byte
    1024byte => 1KB
    1024kb = 1MB
    1024MB = 1GB
    1024GB = 1TB

原文地址:https://www.cnblogs.com/liangying666/p/9117729.html

时间: 2024-10-05 08:13:33

基础二(格式化字符串、运算符和编码)_day02的相关文章

while & 字符串 & 运算符 & 初识编码

while-死循环 While: while 条件: 循环体 while True: print("卡路里") print("好运来") print(2) #该行代码永远不会被执行,因为前面是死循环 运行中的循环程序不能点击"X"关闭,要先点击停止再点击关闭按钮 print(bool(0)) 数字中非0的都是True # 正序输出25-57 count = 25 while count <= 57: print(count) count =

python基础(while、运算符、编码初始)

------------恢复内容开始------------ <!doctype html> while循环 while循环 循环:不断重复着某件事就是循环 while 关键字 死循环:while True: 循环体 while True: # 死循环# print("坚强")# print("过火")# print("单身情歌")# print("郭德纲的小曲")# print("五环之歌")

Python基础二:pycharm的安装及简单使用,while循环,格式化输出,运算符, 编码的初识,git

Python基础二: pycharm的安装及简单使用,while循环,格式化输出,运算符, 编码的初识,git 1.pycharm的安装及简单使用 Tab / Shift + Tab 缩进.不缩进当前行 (先选中代码) Shift + 滚轮 放大缩小代码 Ctrl + ? 注释.解注(先选中代码) Ctrl + d 复制上一行代码 Ctrl + z 撤销 Ctrl + Shift + F10 RUN Ctrl + 左键---->点击 int,str 等可查看源码 2.while 循环(重点) w

python 基础 -02 运算符和编码

一 格式化输出  %s就是代表字符串占位符,除此之外,还有%d, 是数字占位符, 如果把上面的age后面的换成%d,就代表你必须只能输入数字, 这时对应的数据必须是int类型. 否则程序会报错 使用时,需要进行类型转换. int(str) # 字符串转换成int str(int) # int转换成字符串 现在又来了新问题 . 如果想输出: 我叫xxx, 今年xx岁了,我们已经学习了2%的python基础了 在字符串中如果使用%s这样的占位符. 那么所有的%都将变成占位符. 我们的2%也变成占位符

C语言学习(二)——字符串和格式化输入输出

C语言学习(二)——字符串和格式化输入输出 1.char数组类型和空字符 C没有为字符串定义专门的变量类型,而是把它存储在char数组里.数组的最后一个位置显示字符\0.这个字符就是空字符,C用它来标记字符串的结束,其ASCII码的值为(或者等同于)0.C的字符串存储时通常以这个空字符结束,该字符的存在意味着数组的单元数必须至少比要存储的字符数多1.计算机可以自己处理大多数这些细节问题(例如,scanf( )会添加'\0'使得数组内容成为C字符串). 2.strlen( )函数与sizeof运算

一、基础部分-3. 字符串格式化

一.如何打印字符串中的变量呢? #!/usr/bin/env python #-*- coding: utf-8 -*- #循环打印 for i in ["张三","李四","王五"]: print("尊敬的%s,您好.." %i) #字符串中有1个%s,说明有1个变量. #如果字符串中有2个%s,后面的变量要用括号括起来,并且顺序不能错. print('Age: %s. Gender: %s' % (25, True)) %

python基础学习日记(一)注释(二)算术运算符(三)变量的基本使用

一.python程序的注释 注释部份程序运行时不起作用.用于说明代码的用途 1.单行注释 # 开始的一行文字,为单行注释 # 单行注释 print("hello python") # 单行注释 2.多行注释 一对三个引号(单引号或者双引号),为多行注释 ''' 单引号多行注释 ..... 多行注释 ''' print("hello python") """ 双引号多行注释 ..... 多行注释 """ 二.

格式化字符串(二)

格式化字符串(二) 直接使用字符串"."方法的方式格式化字符串. 加强了字符串原有的replace,也就是说,字符串的原有原生方法,用法不变. String.replace({JSON},|Boolean|?) 入门用法. 例如: var string = "{name}是一个实用的{type},包含很多有趣的功能.".replace({ name: "v2", type: "前端轻量级框架" }); console.log(

Python全栈开发【基础二】

Python全栈开发[基础二] 本节内容: Python 运算符(算术运算.比较运算.赋值运算.逻辑运算.成员运算) 基本数据类型(数字.布尔值.字符串.列表.元组.字典) 编码与进制转换 Python 运算符 1.算术运算: 2.比较运算: 3.赋值运算: 4.逻辑运算:  5.成员运算: 基本数据类型 1.数字 int(整型) 1 class int(object): 2 """ 3 int(x=0) -> integer 4 int(x, base=10) -&g