元组(tuple)

 #元组相对列表来说不同之处是只读不可写 读操作和列表一致
 letter_tuple = ('a','b','c','d');
 print(letter_tuple[0]);#result:a
 print(letter_tuple[0:3]);#result:['a', 'b', 'c']
 print(letter_tuple[3::-1]);#result:['c', 'b', 'a']

字典 (dictionary)

 addressDic = {'湖北':['武汉','襄阳'],'湖南':['长沙','岳阳']}
 for province in addressDic:
     cityList = addressDic[province];
     print(province,end = ":");
     for city in cityList:
         print(city,end = ";");
     print();
 #result:
     # 湖北: 武汉;襄阳;
     # 湖南: 长沙;岳阳;

字符串 (string)

 letterStr = 'abcdefg';
 #重复输出
 print(letterStr*2);#result:abcdefgabcdefg
 #切片
 print(letterStr[2:]);#result:cdefg
 #判断是否存在
 print('abc' in letterStr);#result:True
 #格式化输出
 print('abcd%s'%'efg');

 #string的内置方法
 #获取元素个数
 print(letterStr.count('c'));#result:1
 #字符串首字母大写
 print(letterStr.capitalize());#result:Abcdefg
 #指定长度居中
 print(letterStr.center(20,'-'));#result:------abcdefg-------
 #是否以指定元素结尾
 print(letterStr.endswith("g"));#result:True
 #是否以指定元素开头
 print(letterStr.startswith("a"));#result:True
 #指定tab空格长度
 print("a\tb".expandtabs(tabsize=10));#result:a         b
 #返回指定第一个元素索引值
 print(letterStr.find('c'));#result:2
 #格式化
 print("hello {next}".format(next="world"));#result:hello world
 print("name:{name};{age} years old".format_map({"name":"zhangsan","age":12}));#result:name:zhangsan;12 years old
 #返回指定元素索引 不存在时会报错
 print(letterStr.find('c'));#result:2
 #判断只包含数字或字母
 print("deqad#".isalnum());#result:False;
 #判断是否是整形数字
 '.isdigit());#result:True
 #判断是否不是非法命名
 print("123a".isidentifier());#result:False
 #判断是否小写
 print(letterStr.islower());#result:True
 #判断是否大写
 print(letterStr.isupper());#result:False
 #判断是否是个空格
 print(letterStr.isspace());#result:False
 #判断是否每个单词首字母大写
 print(letterStr.istitle())#result:False
 #转小写
 print(letterStr.lower());#result:abcdefg
 #转大写
 print(letterStr.upper());#result:ABCDEFG
 #大小写反转
 print(letterStr.swapcase());#result:ABCDEFG
 #左填充
 print(letterStr.ljust(20,'*'));#abcdefg*************
 #右填充
 print(letterStr.rjust(20,'*'));#*************abcdefg
 #去首尾空白字符
 print("  ade  \n".strip());#result:ade
 #去首部空白字符
 print("  ade  ".lstrip());#result:ade
 #去尾部空白字符
 print("  ade  \n".rstrip());#result:  ade
 #替换
 print(letterStr.replace('g','ghi'));#result:abcdefghi
 #从右往左查找 返回实际位置
 print("acbbbbcss".rfind('c'));#result:6
 #切割字符串 返回列表
 print(letterStr.split('d'));#result:['abc', 'efg']
 #字符串内每个单词首字母大写
 print('hello world'.title());#result:Hello World

队列(queen)

 import queue

 q = queue.Queue()
 q.put(1)
 q.put(2)
 q.put(3)
 print(q.qsize())  # 3 查看队列元素个数

 print(q.get())  # 阻塞

练习

三级联动

 mainDic = {
     'a1':{
         'a1b1':{
             'a1b1c1':{},
             'a1b1c2':{},
             'a1b1c3':{}
         },
         'a1b2':{
             'a1b2c1': {},
             'a1b2c2': {},
             'a1b2c3': {}
         },
         'a1b3':{
             'a1b3c1': {},
             'a1b3c2': {},
             'a1b3c3': {}
         }
     },
     'a2':{
         'a2b1': {
             'a2b1c1': {},
             'a2b1c2': {},
             'a2b1c3': {}
         },
         'a2b2': {
             'a2b2c1': {},
             'a2b2c2': {},
             'a2b2c3': {}
         },
         'a2b3': {
             'a2b3c1': {},
             'a2b3c2': {},
             'a2b3c3': {}
         }
     },
     'a3':{
         'a3b1': {
             'a3b1c1': {},
             'a3b1c2': {},
             'a3b1c3': {}
         },
         'a3b2': {
             'a3b2c1': {},
             'a3b2c2': {},
             'a3b2c3': {}
         },
         'a3b3': {
             'a3b3c1': {},
             'a3b3c2': {},
             'a3b3c3': {}
         }
     }
 };
 currentLayer = mainDic;
 parentLayers = [];
 while True:
     for item in currentLayer:
         print(item);
     choose = input('input your choose:');
     if(choose in currentLayer):
         if not currentLayer[choose]:
             print('last layer');
             continue;
         parentLayers.append(currentLayer);
         currentLayer = currentLayer[choose];
     elif choose=='e':
         currentLayer = parentLayers.pop();
     elif choose=='exit':
         break;
     else:
         print('该项不存在');

 #result:
     # >>a1
     # >>a2
     # >>a3
     # >>input your choose:a2
     # >>a2b1
     # >>a2b2
     # >>a2b3
     # >>input your choose:a2b2
     # >>a2b2c1
     # >>a2b2c2
     # >>a2b2c3
     # >>input your choose:e
     # >>a2b1
     # >>a2b2
     # >>a2b3
     # >>input your choose:e
     # >>a1
     # >>a2
     # >>a3
     # >>input your choose:exit

扩展

批量赋值

 a,b = [1,2];
 print(a);#result:1
 print(b);#result:2

enumerate(iterable:遍历对象,start:起始下标)

该函数用于将一个可遍历的数据对象(如列表、元组或字符串)组合为一个索引序列,同时列出数据和数据下标,一般用在 for 循环当中。

letter_tuple = ['a','b','c','d','e'];
for index,value in enumerate(letter_tuple,1):
    print(index,value);
#result:
    # (1, 1)
    # (2, 2)
    # (3, 3)
    # (4, 4)
    # (5, 5)

取序列长度

 letterStr = 'abcdefg';
 letterList = ['a','b','c','d','e','f','g'];
 print(len(letterStr));#result:7
 print(len(letterList));#result:7

可把序列当做判断条件,为空时返回False,反之True

 list = [];
 if list:print('True');
 else:print('False');
 #result:False;
 list.append(1);
 if list:print('True');
 else:print('False')
 #result:True

python基础(4)-元组&字典&字符串&队列的更多相关文章

  1. python3速查参考- python基础 4 -> 元组 + 字典 + 字符串 的学习

    元组 元组:特点就是内容不可变,算只读的列表,可以被查询,不能被修改 a = 2, print(a) print(type(a)) b = ('a','b','c') print(b[1]) 运行结果 ...

  2. python基础深入(元组、字符串、列表、字典)

    python基础深入(元组.字符串.列表.字典) 一.列表 1.追加 >>>list = [1,2,3,4] #用于在列表末尾添加新的对象,只能单个添加,该方法无返回值,但是会修改原 ...

  3. 2.python基础深入(元组、字符串、列表、字典)

    一,对象与类 对象: python中一切皆为对象,所谓对象:我自己就是一个对象,我玩的电脑就是对象,玩的手机就是对象. 我们通过描述属性(特征)和行为来描述一个对象的. 在python中,一个对象的特 ...

  4. python基础-列表元组字典

    1.列表和元组 列表可以对数据实现最方便的存储.修改等操作 names=["Alex","tenglan","Eric","Rai ...

  5. Python学习---列表/元组/字典/字符串/set集合/深浅拷贝1207【all】

    1.列表 2.元组 3.字典 4.字符串 5.set集合 6.深浅拷贝

  6. python之列表/元组/字典/字符串

    一.列表 格式:list = ['xxx','xxx','xxx'] 性质:可以修改列表内容 copy用法: import copy names = ['] names01 = names #直接引用 ...

  7. 『Python基础-10』字典

    # 『Python基础-10』字典 目录: 1.字典基本概念 2.字典键(key)的特性 3.字典的创建 4-7.字典的增删改查 8.遍历字典 1. 字典的基本概念 字典一种key - value 的 ...

  8. Python基础知识(五)------字典

    Python基础知识(四)------字典 字典 一丶什么是字典 ​ dict关键字 , 以 {} 表示, 以key:value形式保存数据 ,每个逗号分隔 ​ 键: 必须是可哈希,(不可变的数据类型 ...

  9. python基础数据类型--元组(tuple)

    python基础数据类型--元组(tuple) 一.元组的定义和特性 定义:与列表相似,只不过就是将[ ] 改成 ( ) 特性:1.可以存放多个值 2.不可变 3.按照从左到右的顺序定义元组元素,下标 ...

随机推荐

  1. Jquery Post提交时Content-Type的不同取值详解

    四种常见的 POST 提交数据方式 我们知道,HTTP 协议是以 ASCII 码传输,建立在 TCP/IP 协议之上的应用层规范.规范把 HTTP 请求分为三个部分:状态行.请求头.消息主体.类似于下 ...

  2. A*算法详解链接

    A星算法详解(个人认为最详细,最通俗易懂的一个版本) Introduction to the A* Algorithm 路径规划: a star, A星算法详解 实现A星算法

  3. k8s yaml说明

    k8s yaml # yaml格式的pod定义文件完整内容: apiVersion: v1       #必选,版本号,例如v1 kind: Pod       #必选,Pod metadata:   ...

  4. Content of "Essential Software Test Design"

    Content of "Essential Software Test Design" 2015-11-16 PART I 7 TEST DESIGN TECHNIQUES: AN ...

  5. 从零开始搭建FAQ引擎--基于ES的字面匹配

    从零开始搭建FAQ引擎--基于ES的字面匹配

  6. 关于QQ邮箱有时候接受不到邮件的解决

    1.很可能是被当作垃圾邮件拦截了,这时候就要自己找回 2.首先点击邮箱首页 3.在最后一行倒数第三个选择自助查询 4.一般在收信查询或者删信查询里面,找到被删的邮件,添加到白名单就好了

  7. 必读:Spark与kafka010整合

    版权声明:本文为博主原创文章,未经博主同意不得转载. https://blog.csdn.net/rlnLo2pNEfx9c/article/details/79648890 SparkStreami ...

  8. Java 判断字符串 中文是否为乱码

    import java.util.regex.Matcher; import java.util.regex.Pattern; public class ChineseUtill { private ...

  9. windows下自动删除过期文件的脚本

    windows下自动删除过期文件的脚本 前言: 比如日志文件每天都产生,时间长了就会有很大的一堆垃圾.整理一下 定时删除文件的方法. 正文: Windows: 定时删除tomcat日志和缓存.可以保留 ...

  10. 大华等其他NVR接入海康IPC H.264方法

    有一次遇到这个问题,因为时间急,没有注意,这次一个朋友也遇到这个问题,各种百度,也没有看到答案 只好自己研究了一下,最终发现以下方式来解决 下面办法可以解决海康IPC不能能过ONVIF连接到大华等其他 ...