博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
id,is的用法,小数据池的概念及编码知识进阶
阅读量:6624 次
发布时间:2019-06-25

本文共 956 字,大约阅读时间需要 3 分钟。

一:id 查询内存地址

name = 'alex'print(id(name))li = [1,2,3]print(id(li))

二:is  判断的是内存地址

name1 = 'alex@'name2 = 'alex@'print(name1 == name2)print(name1 is name2)

三:小数据池    

      小数据池主要是针对数字,字符串两种类型而言的,对于数字而言,其范围在-5--256之间,对于字符串而言,如果其全部由字母组成,都是指向一个内存地址。如果是数字与str(单个字母)想乘,则20以内(包含20)的是同一个内存地址,其他数据类型 则没有小数据池概念。

四:编码知识进阶

1,不同编码之间是不能互相识别对方的二进制,会报错,或者产生乱码.

2,在你的字符串(文件),存储,传输时,必须使用非unicode的二进制(01010101).
3,py3:字符串:编码方式(在内存中的运行方式):默认都是unicode.

4,字符串和字节的关系

byte       对于非中文: 表现形式:  b'alex'                                                 内部编码:  utf-8 gbk,gb2312...(非unicode) 你设定的.

              对于中文:  表现形式:  b'xe3\xf2\x36\xe3\xf2\x36\'                   内部编码:  utf-8 gbk,gb2312...(非unicode) 你设定的.

str          对于非中文: 表现形式:  'alex'                  内部编码: unicode     

              对于中文:   表现形式:  '中国'                   内部编码: unicode

5,str和byte的转化

1,当字符串为英文时,程序如下:

s = 'alex'b = s.encode('utf-8')b1 = s.encode('gbk')print(s,type(s))print(b,type(b))print(b1,type(b1))

2,当字符串为中文时,程序如下:

s = '中国'b = s.encode('utf-8')b1 = s.encode('gbk')print(s,type(s))print(b,type(b))print(b1,type(b1))

 

 

 

 

 

 

 

 

 

 

 

 

转载于:https://www.cnblogs.com/leiwei123/p/8361644.html

你可能感兴趣的文章
读C#开发实战1200例子记录-2017年8月14日11:20:38获取汉字编码值
查看>>
Fescar 发布 0.3.1 版本, 支持 ZooKeeper 注册中心
查看>>
【死磕 Spring】----- IOC 之解析 bean 标签:BeanDefinition
查看>>
Java部署环境搭建(Linux)
查看>>
使用 will-change 来提升浏览器渲染效果
查看>>
Animation总结(差值器和估值器)
查看>>
Java数据结构与算法(十)-图
查看>>
4.1 在SELinux中客体类存在的目的
查看>>
如何用iPad运行Python代码?
查看>>
PHP学习3——数组
查看>>
E-HPC支持多队列管理和自动伸缩
查看>>
Maven的插件:命令行执行
查看>>
各种设备的CSS3MediaQuery整理及爽歪歪写法
查看>>
CVE-2017-8464远程命令执行漏洞(震网漏洞)复现
查看>>
Java 12 将于3月19日发布,8 个最终 JEP 一览
查看>>
基础为重,Python的基础,成就月薪过万
查看>>
Linux登录那点事
查看>>
angular项目中bootstrap-datetimepicker时间插件的使用
查看>>
通过网络仓库建立本地的yum仓库
查看>>
【web端权限维持】利用ADS隐藏webshell
查看>>