day07(数据类型的相互转换 ,字符编码)

时间:2022-04-25 00:34:11

一,复习:

'''
1,深浅拷贝
  ls = [1,'a',[10]]
  值拷贝:直接赋值 ls1 = ls,ls中的任何值发生改变,ls1也随之发生改变
  浅拷贝:通过copy()方法 ls2 = ls.copy(),ls中存放的值的地址没有改变, 但内部的值发生改变,ls2会随之改变     -- ls = [1, 'a', [10]] => [1, 'a', [100]] = ls2
  深拷贝:通过deepcopy()方法 ls3 = deepcopy(ls),ls中存放的值发生任何改变,ls3都不会随之改变
  
2.元组类型
t = tuple()
元组:
    1.就可以理解为不可变的list
    2.有序 - 可以索引取值,可以切片
    3.不可变 - 长度和内容都不能发生改变
细节:元组中可以存放所有的数据类型,所以存放可变类型数据后,可变类型依然可以发生改变

3.字典类型
d1 = {}
d2 = dict({'a': 1})
d3 = dict(name='Bob') # 所有的key都会用合法的变量名,最终转化为字符串类型的key
d4 = {}.fromkeys('abc', 0) => {'a': 0, 'b': 0, 'c': 0}
key: 要确保唯一性,所以必须为不可变类型
value:存放可以存放的所有类型数据,所以支持所有类型
字典:1.可变 2.没有索引,通过key取值 3.无序的
增删改查:字典名[key名] | 字典名[key名] = 值 | update(dict) | setdefault(key, d_value) | get(key, default)
| pop(key) | popitem() | clear()
循环:keys() | values() | items()
for k, v in dic.items(): # (k, v)
pass 字典的成员运算:完成的就是 key 在不在 目标字典中

4.集合类型
s = set()
集合:1.可变 - 可增可删 2.无序无索引无key - 不能取值不能改值 3.for可以对集合取值,取值的结果顺序不确定
特定:不能存放重复的数据(去重效果)

  # s1.symmetric_difference_update(s2)  # 将集合s1与s2的运算结果设置给s1
'''

二,数据类型的相互转换

'''
1,哪些类型可以转化为数字
  res = int('10')
   print(res)
   res = int('-3')
   print(res)
   res = float('.15')
   print(res)
   res = float('-.15')
   print(res)
   res = float('-3.15')
   print(res)
    2,数字转化字符串
   print(str(10))  3,字符串与列表相互转换*****    s = 'abc123呵呵'
   print(list(s))   #['a', 'b', 'c', '1', '2', '3', '呵', '呵'] 没有对应的 str(ls)
   ls =
['a', 'b', 'c', '1', '2', '3', '呵', '呵']
   n_s = ''.join(ls)
   print(n_s)         #abc123呵呵
      s1 =
'a b c 1 2 3 呵 呵'
   res = s1.split()     #默认按空格拆分
   print(res)        #['a', 'b', 'c', '1', '2', '3', '呵', '呵']    
 #必须掌握*****
  
  列表与字符串相互转换*****
   s2 = 'ie=UTF-8&wd=你好帅'
   res = s2.split('&')
   print(res)        
# ['ie=UTF-8', 'wd=你好帅']
    ls2 = ['ie=UTF-8','wd=你好帅']
   n_s2 = '@'.join(ls2)
   print(n_s2)        
# ie=UTF-8@wd=你好帅
 4,需求: 字符串与列表的相互转换: "ie=UTF-8&wd=你好帅" => [('ie', 'UTF-8'), ('wd', '你好帅')]

   res = []
   s4 = "ie=UTF-8&wd=你好帅"
   ls4 = s4.split('&')      # ['ie=UTF-8', 'wd=你好帅']    for ele in ls4:        # v = ie=UTF-8 | wd=你好帅
      k,v = ele.split('=')  # k: ie v: UTF-8
      res.append((k,v))
   print(res)           #[('ie', 'UTF-8'), ('wd', '你好帅')]
  

 5,需求:字符串与字典的相互转换: "ie=UTF-8&wd=你好帅" => {'ie': 'UTF-8', 'wd': '你好帅'}
   res = {}
   s5 =
"ie=UTF-8&wd=你好帅"
   ls5 = s5.split('&')     # ['ie=UTF-8', 'wd=你好帅']   
   for ele in ls5:        
      k,v = ele.split('=') #k:ie v=UTF-8
      res[k] = v
   print(res)           #{'ie': 'UTF-8', 'wd': '你好帅'}

 6,需求:列表与字典的相互转换:[('ie', 'UTF-8'), ('wd', '你好帅')] => {'ie': 'UTF-8', 'wd': '你好帅'}
   res = {}
   ls6 = [('ie', 'UTF-8'), ('wd', '你好帅')]
   for k,v in ls6:
      res[k] = v
   print(res)
  
 7,list 与taple ,set 直接转换——直接 类型()  
  8.需求:将汉字转化为数字
  # 将 壹、贰、叁、肆、伍、陆、柒、捌、玖、拾、佰、仟
  # 转化为 1、2、3、4、5、6、7、8、9、10、100、100
  ## 作业:壹仟捌佰玖拾叁 => 1893
  num_map = {
  '壹': 1,
  '贰': 2,
   '仟': 1000
  }
  ls8 =['贰', '壹', '仟']
  res = []
  for v in ls8:
    num = num_map[v]  #通过key去映射拿到对应的值,完成
'贰' => 2
    res.append(num)
  print(res)
'''

三,字符编码:

# 测试一下
# 学习字符编码的问题:解决乱码问题 # 数据 从 硬盘 => 内存 => cpu
# 应用程序打开文本文件的三步骤
# 1.打开应用程序
# 2.将数据加载到内存中
# 3.cpu将内存中的数据直接翻译成字符显示给用户 # python解释器
# 1.打开python解释器
# 2.将数据加载到内存中
# 3.cpu将内存中的数据解释执行将结果显示给用户,如何解释执行不能通过,将错误信息提供给用户 # 编码的发展史
# 电脑只能识别高低电频对应的0,1信息 => 问题:如何将世间万物信息存放到内存中
# 世间万物信息 => 0,1形式的数据 => 电脑中存放,将该过程逆向操作,就是访问已存储的数据信息 # 编码表
# 人能识别的字符 <=> 机器能识别的字符:一定存在一种固定的对应关系
# 编码表:一定范围内人能识别的字符与机器能识别的字符形成的对应关系表(映射表) # 1.ASCII表:英文字母、英文符号、数字与机器能识别的字符的对应关系表,8个二进制位就能存放完这所有的对应关系 => 1字节
# python2采用的默认编码是ASCII,早期并不支持中文编程
# 2_1.GBK:中文与与机器能识别的字符的对应关系表(完全兼容ASCII表),16个二进制位能存放所有汉字与ASCII之前的对应关系 => 2个字节
# 2个字节能否存放常用汉字 => 16个二进制位 2^15
# print(pow(2, 15))
# 2_2.Shift_JIS | Euc-kr:日文 | 韩文 与机器能识别的字符的对应关系表(完全兼容ASCII表) # 乱码:存的编码格式与取的编码格式不一致
# 3.Unicode万国码:世间中常用国家的常用字符与机器能识别的字符的对应关系表 # 转码:Unicode存在汉字与二进制对应关系,GBK也存在汉字与二进制对应关系,将GBK存放的数据转存到Unicode数据 # 均采用Unicode编码表,只是存放数据采用字节数不一致,utf-8与utf-16是Unicode编码表的两种体现方式 # utf-8:以1个字节存放英文,以3 | 6个字节存放汉字,在英文数据过多时,更深空间,用来传输效率更高
# utf-16:所有支持的符号都采用2个字节存放,读存数据采用定长,不用计算,读存效率高 # 硬盘到内存需要数据的传输,内存到CPU需要数据的传输,所有都采用utf-8
# 内存需要高速读写,采用utf-16 # 学习的结晶:编码与解码要统一编码
# 操作文本字符
res = "汉字呵呵".encode('utf-8') # 编码:将普通字符串转化为二进制字符串
print(res) res = b'\xe5\x91\xb5\xe5\x91\xb5'.decode('GBK') # 解码:将二进制字符串转化为普通字符串
print(res)
res = b'\xe5\x91\xb5\xe5\x91\xb5'.decode('utf-8')
print(res)

day07(数据类型的相互转换 ,字符编码)的更多相关文章

  1. python-02 数据类型、字符编码、文件处理

    标准数据类型 Python3 中有六个标准的数据类型: Number(数字) String(字符串) List(列表) Tuple(元组) Sets(集合) Dictionary(字典) 数字 #整型 ...

  2. python数据类型及字符编码

    一.python数据类型,按特征划分 1.数字类型 整型:布尔型(True,False).长整型(L),会自动帮你转换成长整型.标准整型 2.序列类型 字符串(str).元组(tuple).列表(li ...

  3. Python之旅:数据类型、字符编码、文件处理

    一 引子 1 什么是数据? x=10,10是我们要存储的数据 2 为何数据要分不同的类型 数据是用来表示状态的,不同的状态就应该用不同的类型的数据去表示 3 数据类型 以下每个类型都是有详细介绍链接的 ...

  4. DAY2-python数据类型、字符编码、文件处理

    阅读目录 一.引子 二.数字 三.字符串 四.列表 五.元祖 六.字典 七.集合 八.数据类型总结 九.运算符 十.字符编码 十一.文件处理 一.引子 1 什么是数据? x=10,10是我们要存储的数 ...

  5. Day02&colon;数据类型、字符编码、文件处理

    一.基础数据类型与其内置方法 1. int基本使用:int(3.1) 用途:记录年龄,职级等 只能将包含纯数字的字符串类型转换成整形 特点:1.存一个值. 2.不可变 2.float基本使用 floa ...

  6. python数据类型、字符编码、文件处理

    介绍: 1.什么是数据? 例:x=10,10是我们要存储的数据 2.为何数据要分不同的类型? 数据是用来表示状态的,不同的状态用不同的类型的数据去表示 1.数据类型 1.数字(整形,长整形,浮点型,复 ...

  7. Python基础(四)--数据类型、字符编码、文件处理

    一.数据类型 1. 数据类型 数字(整形,长整形,浮点型,复数) 字符串 字节串(字节bytes类型) 列表 元组 字典 集合 2. 按照以下几个点展开数据类型的学习 #=============== ...

  8. 二、python数据类型、字符编码、文件处理

    一. 前言 1. 什么是数据: x = 10,10就是我们要存储的数据 2. 为何数据要分不同的类型 数据是用来表示状态的, 不同的状态就应该用不同类型的数据去表示 3. 数据类型 数字(整型.长整型 ...

  9. python学习笔记之数据类型、字符编码、文件处理

    1.数据类型 1.数字(int,float) 整形(int):定义 age=20  #本质age=int(20) 浮点类型:salary=3000.3 #本质salary=float(3000.3) ...

  10. python学习第二节 数据类型、字符编码、文件处理

    标准数据类型 Python3 中有六个标准的数据类型: Number(数字) String(字符串) List(列表) Tuple(元组) Sets(集合) Dictionary(字典) 数字 #整型 ...

随机推荐

  1. java操作数据库增删改查的小工具2--TxQueryRunner

    当涉及到多表查询时,如数据库中有两张表分别为t_person和t_address,表结构如下: 其中t_person的外键为t-address的主键aid, 新建两个javaBean类,Person ...

  2. Set集合对象比较两个元素的方法

    Set集合对象比较两个元素的方法并不是根据“equals()”方法的返回值来比较.而是用“hashCode()”方法来进行判断.只要两个元素的“hashCode()”方法的返回值相同,就认为两个元素相 ...

  3. 一、HTML4背景知识

    前言 本教程针对已经基本熟悉HTML4基本标签的人. HTML的发展历程 HTML 1.0: 1993年6月由IETF(Internet Engineering Task Force, 互联网工程工作 ...

  4. Python 学习笔记(3) - 控制流、函数

    控制流语句if.while.for.break.continue以上从最终作用效果来讲,同学过的其他语言没有什么不同.需要注意的只是语法,而Python 在语法上是如此让人赞叹和喜欢啊. 控制流语句的 ...

  5. POJ 1222 EXTENDED LIGHTS OUT&lpar;翻转&plus;二维开关问题&rpar;

    POJ 1222 EXTENDED LIGHTS OUT 今天真是完美的一天,这是我在poj上的100A,留个纪念,马上就要期中考试了,可能后面几周刷题就没这么快了,不管怎样,为下一个200A奋斗, ...

  6. &&num;127827&semi; vue循环渲染本地图片不显示? &&num;127827&semi;

    teamList: [{ title: '大数据拍牌', imgUrl: './img/data.jpg', introduce: '5星服务:强烈推荐', cost: '15000', bail: ...

  7. Abp &plus; gRpc 如何实现用户会话状态传递

    0.背景 在实际项目当中,我们采用的是 Abp 框架,但是 Abp 框架官方并没有针对 Grpc 进行模块封装.基于此我结合 Abp 与 MagicOnion 封装了一个 Abp.Grpc 模块,它包 ...

  8. python3打包成exe---pyinstaller方法

    前言: 主要介绍python3的pyinstaller打包方法 pyinstaller安装参考地址:http://www.pyinstaller.org/ pywin32的下载地址:https://s ...

  9. 【BZOJ 2333 】&lbrack;SCOI2011&rsqb;棘手的操作(离线&plus;线段树&vert;可并堆-左偏树)

    2333: [SCOI2011]棘手的操作 Description 有N个节点,标号从1到N,这N个节点一开始相互不连通.第i个节点的初始权值为a[i],接下来有如下一些操作: U x y: 加一条边 ...

  10. AtCoder Beginner Contest 103

    https://beta.atcoder.jp/contests/abc103 A - Task Scheduling Problem Time Limit: 2 sec / Memory Limit ...