一、 基本数据类型常用功能:
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的项

怎么用python查看excel中的指定列名的序号_元组

#查看对象的类,或对象所具备的功能
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("商品不存在")

人的思维,观点是一直都会进化的。如果现在的思维,观点看法;和十年前的一模一样的话。那就可以说,你这十年是白活的。