一、 基本数据类型常用功能:
1. 整数 int
#int内部优化
n1=123
n2=n1 n1= 123
n2= 123
========2份内存=========
if -5~257:
n1= 123
n2 =123
else:
n1= 123
n2= 123
======》对象的内存地址 = ID(对象或对象的变量名)
#Python 内容优化:在-5~257默认同一个地址码
#查看内存地址:ID(变量名)
#查看字符串、数组长度:len(字符串、数组)
#长度限制
用int,超出了范围
32 -2**31~2**31-1
64 -2**63~2**63-1
long在Python没有长度限制 获取可表示的二进制最短位数
n = 4
w = n.bit_length()
print(w)
2.字符串  str:字符串就是一个有字符组成的序列。
str
s1 ="dsa"
s2 =str("dsa")
# s1=str()#s1 =""
#无参数,创建空字符串
#一个参数,创建普通字符串
#两个参数,int(字节,编码)
#两端去除空格除去两侧(不包括内部)空格的字符串
    s1.strip()
#以.....开头
s1.startswith
#找子序列,返回子序列所在位置的最左端索引值
s1.find
#将字符串中的某个子序列替换成指定的值
s1.replace(“is”.“eez”)
# 变大写
s1.upper()
# 是。。。吗?
s1.isalpha()
#lower 把字符串变成小写字母
#jion 连接序列中的元素 与 split将字符串分割成序列 #公共功能 1.字符==》字节
utf-8编码==》一个汉字为3个字节
gbk编码 ==》一个汉字为2个字节
编码、for:把自己名字分别用二进制、八进制、十六进制写出来
name = "刘飞"
for i in name:
print(i)
bytes_list = bytes(i,encoding ="utf-8")
print(bytes_list)
print(bytes(i,encoding ="utf-8")
   for b in bytes_list:
字节默认16进制
print(b)
#3.5 for循环时候,循环的每一个元素是“字节“
#bytes_list = bytes("字符串” ,encoding ="utf-8")
print(bytes_list) #默认没一个字节都是16进制表示
# for b in bytes_list:
print(b) #默认每一个字节都是10进制表示
#10进制的数字 ==》 2进制
bin(10进制的数字)
len
id
#bytes可以将字符串转换字节
# py2.X for循环中遇到中文用字节循环即(2*3)
# py3.x for循环中遇到中文严格按照字符循环
3.布尔值  bool
4.列表 list
元素的集合
name_list = ["123","abc","sdf"]
# print(name_list[0:2])
# print(name_list[2:len(name_list)])
#
a.# name_list.append("asc") #append在列表末尾追加新的对象,单个加入
# name_list.append("asc") # print(name_list)
b.# print(name_list.count("asc")) #count统计某个元素在列表中出现的个数
# temp= [111,123,145,123,15]
c.# name_list.extend(temp) #extend在列表末尾批量的把一组列表加入到前者中 # print(name_list)
d.#print(name_list.index("sdf"))#index从列表中找出某个值第一个位置的索引值 e.# name_list.insert(1,"156") #insert将对象插入列表中
# print(name_list) f.# name_list.pop() #pop移除列表中的一个元素,当括号没有数字时默认是最后一个
# print(name_list) g.# name_list.remove("abc") # remove移除列表中某个值的第一个匹配项
# print(name_list) h.# name_list.reverse() # reverse将列表中的元素反向存放
# print(name_list) i.name_list.sort()
print(name_list) #sort用于原位置在列表中进行排序
g.print(name_list)
del name_list[1]#del删除某个元素
print(name_list)
k.name_tuple = ("ale","123")
#索引
print(name_tuple[0])
#len
print(name_tuple[len(name_tuple)-1])
#for
for i in name_tuple:
print(i)
#count 计算元素出现的个数
print(name_tuple.count("ale"))
#index 获取指定元素的索引位置
print(name_tuple.index("ale"))
#不能删除
5.元组    tuple
元组跟列表一样也是一种序列,但是不能修改
t=(11,12,123)
t=(11,123,{"alee",{"as":"asd"}}
元组,儿子不能改变
元组,儿子不能变,但孙子能改变如上字典里面的
一般字符串,执行一个功能,生成一个新内容,但原来的内容不变
list、tuple、dict,执行一个功能,生成一个新内容,原来的内容会改变

6.字典 dict
字典默认循环key的值 要循环整个需要dict.items()

键 :值对称为项,项之间用逗号隔开 有大括号括起来。 user_info={"name": "al", "age": 12, "gender": "m"}
formkeys与单独写的同一个的字典区别
# s=dict.fromkeys({"k1","k2","k3"},[])
# print(s)
# s["k1"].append("x")#共用一块列表
# print(s) s={"k1":[],"k2":[],"k3":[]}
s["k1"].append("x")#分别用了三块列表
print(s)
 
a.len(d)返回d中的项(键-值对)的数量
b.d[k]返回关联到键k上的值
c.d[k]=v将值v关联到键k上
d.del d[k]删除键为k的项
e.k in d 检查d中是否有含有键为k的项


#查看对象的类,或对象所具备的功能
1. # type
# temp = "ab"
# t = type(temp)
# print (t)
# str ,ctr+鼠标左,找到 str类,内部所有方法 2. # temp = "ab"
# print (dir(temp)) 3. # temp = "ab"
# help(type(temp)) 4. temp ="ab "
temp.upper()
查找方法:鼠标放在upper()上 按住Ctrl +鼠标左键,会自动定位到 upper功能处
二、 索引:序列中的所有元素都是编号的---从0开始递增。这些元素可以通过编号分别访问。索引0指向第一个元素。 s1[0] 只能取一个元素
分片: 分片操作的实现需要提供两个索引作为边界,第一个索引的元素是包含在分片内的,而第二个则不包含在分片内(1=<元素<n) s1[0:1] 取多个元素
enumerate
#enumerate自动生成一列,默认从0自增一
#字符串=》数字 , int(字符串)
# li=["电脑","x鞋子","生活用品","硬盘"]
# for key ,item in enumerate(li,1):
# print(key,item)
# s=input("请输入商品:")
# # 字符串转换成int
# s_num = int(s)
# print(li[s_num-1]) # 索引 # li=["电脑","x鞋子","生活用品","硬盘"]
# s= input("请输入内容:")
# b= li.index(s)
# print(b) #range/xrange
#py2.7
#range:用获取指定方位内的数,range(0,10000000) 内存立刻执行
#xrange: 用获取指定方位内的数,range(0,10000000) 在内存不创建,只有在for循环中迭代时候创建, # py3 ,range等同于py2.7中的xrange每循环一次就创建一次数值
作业:
一、s=[11,22,33,44,55,66,77,88,99,90]将所有大于66值保存在字典中的第一个key中,将小于66的值保存在第二个key的值中。
1.
s=[11,22,33,44,55,66,77,88,99,90]
s1=[]
s2=[]
for i in s:
if i < 66:
s1.append(i)
else:
s2.append(i)
s3={"k1":s1,"k2":s2}
print(s3)
2.
dict = {"k1":[],"k2":[]}
s=[11,22,33,44,55,66,77,88,99,90]
for i in s:
if i <= 66:
dict["k1"].append(i)
else:
dict["k2"].append(i)
print(dict)

二、查找列表中元素,移除空格,并查找以a或A开头并且以C结尾的所有元素

s=["alex","aric","Alex","Tong"]
tu=("alex","arice","Alex","Tong")
dict={"k1":"alex","k2":"arice","k3":"arice","k3":"Alex","k4":"Tong"}
# s=["alex","aric","Alex","Tong"]
# for i in s:
# new_i=i.strip()
# if (new_i.startswith("a") or new_i.startswith("A"))and new_i.endswith("c"):
# print(new_i) # tu=("alex", "aric", "Alex", "Tong")
# for i in tu :
# new_i =i.strip()
# # if (new_i.startswith("a") or new_i.startswith("A")) and new_i.endswith("c"):
# if new_i.endswith("c"):
# if new_i.startswith("a") :
# pass
# if new_i.startswith("A"):
# pass
# print(new_i) dict={"k1":"alex","k2":"aric","k3":"arice","k3":"Alex","k4":"Tong"}
# for i in dict.values():
# new_i = i.strip()
# if (new_i.startswith("a") or new_i.startswith("A")) and new_i.startswith("c"):
# print(i)
# # if new_i.endswith("c"):
# # if new_i.startswith("a") :
# # pass
# # if new_i.startswith("A"):
# # pass
# # print(new_i)
三、
b= ["手机","电脑","鼠标垫","游艇"],用户输入序号,显示用户选中的商品
b= ["手机","电脑","鼠标垫","游艇"]
# s1=input("请输入商品:")
# a=s.index(s1)
# print(a) for i,j in enumerate(b):
print(i+1,j)
num=input("num:")
num = int(num)
len_b=len(b)
if num >0 and num <= len_b:
print(b[num-1])
else:
print("商品不存在")

      

python基本数据类型剖析的更多相关文章

  1. python源码剖析学习记录-01

    学习<Python源码剖析-深度探索动态语言核心技术>教程         Python总体架构,运行流程   File Group: 1.Core Modules 内部模块,例如:imp ...

  2. python 基本数据类型分析

    在python中,一切都是对象!对象由类创建而来,对象所拥有的功能都来自于类.在本节中,我们了解一下python基本数据类型对象具有哪些功能,我们平常是怎么使用的. 对于python,一切事物都是对象 ...

  3. Python开发【第二章】:Python深浅拷贝剖析

    Python深浅拷贝剖析 Python中,对象的赋值,拷贝(深/浅拷贝)之间是有差异的,如果使用的时候不注意,就可能产生意外的结果. 下面本文就通过简单的例子介绍一下这些概念之间的差别. 一.对象赋值 ...

  4. python常用数据类型内置方法介绍

    熟练掌握python常用数据类型内置方法是每个初学者必须具备的内功. 下面介绍了python常用的集中数据类型及其方法,点开源代码,其中对主要方法都进行了中文注释. 一.整型 a = 100 a.xx ...

  5. 闲聊之Python的数据类型 - 零基础入门学习Python005

    闲聊之Python的数据类型 让编程改变世界 Change the world by program Python的数据类型 闲聊之Python的数据类型所谓闲聊,goosip,就是屁大点事可以咱聊上 ...

  6. python自学笔记(二)python基本数据类型之字符串处理

    一.数据类型的组成分3部分:身份.类型.值 身份:id方法来看它的唯一标识符,内存地址靠这个查看 类型:type方法查看 值:数据项 二.常用基本数据类型 int 整型 boolean 布尔型 str ...

  7. Python入门-数据类型

    一.变量 1)变量定义 name = 100(name是变量名 = 号是赋值号100是变量的值) 2)变量赋值 直接赋值 a=1 链式赋值  a=b=c=1 序列解包赋值  a,b,c = 1,2,3 ...

  8. Python基础:八、python基本数据类型

    一.什么是数据类型? 我们人类可以很容易的分清数字与字符的区别,但是计算机并不能,计算机虽然很强大,但从某种角度上来看又很傻,除非你明确告诉它,"1"是数字,"壹&quo ...

  9. python之数据类型详解

    python之数据类型详解 二.列表list  (可以存储多个值)(列表内数字不需要加引号) sort s1=[','!'] # s1.sort() # print(s1) -->['!', ' ...

随机推荐

  1. k8s之资源指标API部署metrics-server

    1.部署metrics-server 从v1.8开始,引入了新的功能,即把资源指标引入api,资源指标:metrics-server,自定义指标:prometheus,k8s-prometheus-a ...

  2. 阿里云Centos7 配置二级域名

    之前在自己的服务器上安装了laravel,现在给它个二级域名!结果发现了个小坑= =.不说了,上步骤 首先你要有个自己的域名,可以在万网上买一个,我的还是蛮便宜的... 进入你的阿里云管理台 选择云解 ...

  3. hdu 1068 最大子序列和变形,,,

    #include<iostream> #include<cstdio> #include<cstring> #include<algorithm> #d ...

  4. Java写学生管理系统

    package Homework08;/*调试了一上午,收获:学会了昨天的debug的使用吸取教训:Student stus[]=new Student[2]; for (int i=0;i<s ...

  5. [转载]linux的top命令中cpu信息的含义

    https://www.cnblogs.com/wjoyxt/p/4918742.html 原文很好,我就不摘录了.

  6. mysql中binglog底层原理分析

    binglog 是一个二进制的日志文件,会记录mysql的数据更新或潜在个跟新 (delete from table where id =xxx) 主从复制就是依靠binglog master -sl ...

  7. mysql管理工具之pt

    之前我一直用Seconds_behind_master来衡量主从的延迟,今天看到文档,才觉得多么不可靠!以下是官方文档的描述: In essence, this field measures the ...

  8. ASE19团队项目alpha阶段model组 scrum4 记录

    本次会议于11月6日,19时整在微软北京西二号楼sky garden召开,持续50分钟. 与会人员:Jiyan He, Kun Yan, Lei Chai, Linfeng Qi, Xueqing W ...

  9. 关于postgres数据库部署之后,发现不能被外机连接解决办法

    数据库 部署完毕之后,用其他机器的navcat连接发现不能连接,如下报错信息 于是在数据库服务器上查询是否启动正常,端口是否正常,发现都没有问题,由于之前也遇到了mysql部署之后,不能被其他机器访问 ...

  10. ContextMenu菜单创建 上下文菜单的基本认识q

    MainActivity.class public class MainActivity extends AppCompatActivity { @Override protected void on ...