Python基础Day3—容器类型之字符串、列表

字符串

字符串: 使用引号包裹起来的数据就是字符串

字符串定义方式有四种:

单引号字符串:

my_str1 = 'hello'

双引号字符串:

my_str2 = "你好"

三个单引号字符串:

### 三个单引号/双引号之间可以定义多行字符串
my_str3 = '''
哈哈
嘻嘻  
嘿嘿'''

三个双引号字符串:

### 三个单引号/双引号之间可以定义多行字符串
my_str4 = """A
B
C"""

我们看print之后的效果:

print(my_str1, type(my_str1))
print(my_str2, type(my_str2))
print(my_str3, type(my_str3))
print(my_str4, type(my_str4))

#########  输出为  ############

hello <class 'str'>
你好 <class 'str'>

哈哈
嘻嘻
嘿嘿 <class 'str'>
A
B
C <class 'str'>

总结: 如果字符串内容有多行那么我们使用三引号字符串,如果字符串内容只用一行那么可以使用单引号或者双引号字符串

1. 字符串输入和输出

之前在学习input的时候,通过它能够完成从键盘获取数据,然后保存到指定的变量中:

name = input("请输入您的姓名:")
age = int(input("请输入您的年龄:"))
address = input("请输入您的地址:")

print("我叫:%s 年龄: %d 地址: %s" % (name, age, address))

#########  输出为  ############

请输入您的姓名:小明
请输入您的年龄:26
请输入您的地址:北京
我叫:小明 年龄: 26 地址: 北京

注意:input获取的数据,都以字符串的方式进行保存,即使输入的是数字,那么也是以字符串方式保存。我们这里print里年龄后面的占位符是整数型%d,所以需要通过int(input("请输入您的年龄:"))操作将字符型转成整数型。如果我们年龄的输出也用%s占位,那就不需要转型操作。

2. f-string 的使用

f-string是python3.6及以上版本提供动态绑定字符串数据的一个新特性 —— 相当于字符串动态绑定数据格式化占位符的简化版本。

用法一:

name = input("请输入您的姓名:")
age = int(input("请输入您的年龄:"))
# f-string:动态绑定数据只需要一对大括号即可
my_str = f"我叫:{name} 年龄:{age}"
print(my_str, type(my_str))

#########  输出为  ############

请输入您的姓名:小明
请输入您的年龄:26
我叫:小明 年龄:26 <class 'str'>

用法二:

num1 = int(input("请输入第一个数字:"))
num2 = int(input("请输入第二个数字:"))

message = F'{num1} + {num2} = {num1 + num2}'
print(message)

#########  输出为  ############

请输入第一个数字:10
请输入第二个数字:90
10 + 90 = 100

提示:字符串动态绑定数据格式化占位符方式最通用, 不涉及版本问题

3. 下标和切片

下标-索引

  • 下标:又称为索引,其实就是数字,下标在python里面可以分为正数下标和负数下标。
  • 下标:根据下标可以获取和删除指定位置的数据,下标是用来标识不同数据,通俗理解下标是用来区分不同数据的。

如果有字符串 : name = 'abcdef',在内存中的实际存储如下 :


如果想取出部分字符,那么可以通过下标的方法,(注意python中下标从 0 开始)

name = 'abcdef'

   print(name[0])
   print(name[1])
   print(name[2])

#########  输出为  ############
a
b
c

切片

切片:根据下标范围获取对象(字符串,列表,元组)中的一部分数据。

切片的语法格式:

my_str[开始下标: 结束下标: 步长] 注意点:结束下标不包含,步长不指定默认是1。

切片获取字符串中一部分数据:

my_str = "abcedf"
result = my_str[0:3]
print(result)

#########  输出为  ############
abc

获取前三个字符串的简写:

my_str = "abcedf"
result = my_str[:3]
print(result)

#########  输出为  ############
abc

根据指定下标获取到最后一个数据简写方式:

my_str = "abcedf"
result = my_str[3:]
print(result)

#########  输出为  ############
edf

获取倒数后面三个字符串数据的简写方式 :

my_str = "abcedf"
result = my_str[-3:]
print(result)

#########  输出为  ############
edf

获取字符串中的整个数据 :

my_str = "abcedf"
result = my_str[:]
print(result)
result = my_str[::1]
print(result)

#########  输出为  ############
abcedf
abcedf

指定步长:

my_str = "abcedf"
result = my_str[::2]
print(result)

result = my_str[-2:-6:-1]
print(result)

#########  输出为  ############
acd
decb

注意点:切片的范围如果有问题,获取数据是不会报错,但是获取的数据是一个空的字符串数据

总结:如果步长是正数表示从左到右取值,如果步长是负数表示从右到左取值。

  • 下标-索引是通过下标取某一个元素
  • 切片是通过下标去某一段元素

(面试题)给定一个字符串aStr, 请反转字符串

python 字符串快速逆置:

aStr = "hello"
print(aStr[::-1])  # 从后向前,按步长为1进行取值

#########  输出为  ############
olleh

扩展总结:

s = 'Hello World!'

print(s[4])

print(s)

print(s[:]) # 取出所有元素(没有起始位和结束位之分),默认步长为1

print(s[1:]) # 从下标为1开始,取出 后面所有的元素(没有结束位)

print(s[:5])  # 从起始位置开始,取到 下标为5的前一个元素(不包括结束位本身)

print(s[:-1]) # 从起始位置开始,取到 倒数第一个元素(不包括结束位本身)

print(s[-4:-1]) # 从倒数第4个元素开始,取到 倒数第1个元素(不包括结束位本身)

print(s[1:5:2]) # 从下标为1开始,取到下标为5的前一个元素,步长为2(不包括结束位本身)

#########  输出为  ############
o
Hello World!
Hello World!
ello World!
Hello
Hello World
rld
el

4. 字符串常见操作

(1) find

find: 根据指定字符串,获取字符串所在的下标

注意:如果没有找到对应的字符串,返回 -1,这里 -1 不是最后一个元素表示的是没有找到字符串的下标位置。

比如,我们有一个字符串:my_str = "hello",我们想知道 e 这个字符串是否在my_str中前两个位置,如果在就返回e 所在的下标,不在返回 -1:

my_str = "hello"
result = my_str.find("e", 0, 2)
print(result)

############## 运行结果 ###############

1

my_str.find("查找的指定字符串", 开始下标, 结束下标[不包含])
my_str.find("e", 0, 2):查找e是否在hello中的前两个字符中,如果在就返回所对应的下标。

再比如,有字符串my_str = 'you are more than what you have become ',检测字符串 more 是否包含在my_str中,如果包含则返回more中第一字母的索引值(所对应的下标),否则返回-1:

my_str = 'you are more than what you have become '
result = my_str.find("more", 0, len(my_str))
print(result)

############## 运行结果 ###############

8

my_str.find("more", 0, len(my_str)) 查找字符串 more 是否在 'you are more than what you have become ' 中。
注意:my_str.find("more", 0, len(my_str)) = my_str.find("more")

在指定区间内查找指定字符:

my_str = 'you are more than what you have become '
result = my_str.find("more", 0, 7)
print(result)

############## 运行结果 ###############

-1
  • my_str.find("more", 0, 7) :查找字符串 more 是否在'you are more than what you have become '前7个字符中,不存在就返回 -1。

(2) index

index: 根据指定字符串,获取字符串所对应的下标

my_str = "hello"
result = my_str.index("h", 0, 2)

print(result)

############## 运行结果 ###############

0

my_str.index("查找的指定字符串", 开始下标, 结束下标[不包含])

  • my_str.index("h", 0, 2):查找 h 是否存在 hello 中前两个字符中,如果存在返回字符串所对应的下标。

如果查找的字符串不存在 find 会返回 -1 ,但这里会报错:

my_str = "hello"
result = my_str.index("l", 0, 2)
print(result)

############## 运行结果 ###############

ValueError: substring not found

my_str.index("l", 0, 2):查找 lhello 前两个字母中所对应的下标,没有找到指定字符串就报错。

(3) count

count: 统计指定字符串出现次数

my_str = "hello"
result = my_str.count("l", 0, 3)
print(result)
result = my_str.count("l")
print(result)

############## 运行结果 ###############

1
2

my_str.count("统计的指定字符串", 开始下标, 结束下标[不包含])

  • my_str.count("l", 0, 3):统计字符串lhello中前三个字符中出现的次数;
  • my_str.count("l"):统计字符串lhello中出现的次数
    ``

(4) replace

replace: 根据指定字符串进行替换

my_str = "hello"
result = my_str.replace("l", "w", 1)
print(result)
result = my_str.replace("l", "w", 2)
print(result)
result = my_str.replace("l", "w")
print(result)

############## 运行结果 ###############

hewlo
hewwo
hewwo

my_str.replace("要替换的字符串", "替换后的字符串", 替换的次数[默认是全部替换,1表示替换1次])

  • my_str.replace("l", "w", 1): 将hello中的 l 替换成 w 只替换一次;
  • my_str.replace("l", "w"):将hello中的 l 全部替换成 w

(5) split

根据指定字符串进行分割数据,返回是一个列表

my_str = "苹果,橘子,香蕉"
result = my_str.split(",", 1)
print(result, type(result))

############## 运行结果 ###############

['苹果', '橘子,香蕉'] <class 'list'>

my_str.split("指定分割的字符串", 分割的次数[默认是-1表示全部分割,1表示分割1次])

  • my_str.split(",", 1):将字符串my_str = "苹果,橘子,香蕉"按照指定字符:, 进行分割一次
my_str = "苹果,橘子,香蕉"
result = my_str.split(",")
print(result, type(result))

############## 运行结果 ###############

['苹果', '橘子', '香蕉'] <class 'list'>
  • my_str.split(","):将字符串my_str = "苹果,橘子,香蕉"按照指定字符:, 全部分割。

(6) startswith

startswith: 判断是否是以指定字符串开头

my_str = "http://www.baidu.com"
result = my_str.startswith("ftp://")
print(result)

############## 运行结果 ###############

False
  • my_str.startswith("ftp://"):判断 字符串my_str = "http://www.baidu.com" 是否以ftp://开头

(7) endswith

endswith: 判断是否是以指定字符串结尾

my_str = "http://www.baidu.com"
result = my_str.endswith("com")
print(result)

############## 运行结果 ###############

True
  • my_str.endswith("com"):判断字符串 my_str = "http://www.baidu.com" 是否以com结尾。

(8) lstrip - 去除左边空格

my_str = "    abc    "
print(my_str)
# 去除左边空格
result = my_str.lstrip()
print(result)

############## 运行结果 ###############

    abc    
abc    

(9) rstrip - 去除右边空格

my_str = "    abc    "
print(my_str)
# 去除右边空格
result = my_str.rstrip()
print(result)

############## 运行结果 ###############

    abc    
    abc

(10) strip - 去除两边空格

my_str = "    abc    "
print(my_str)

# 去除两边空格
result = my_str.strip()
print(result)

############## 运行结果 ###############

    abc    
abc

去除左边、右边、两边的空格总体效果:

my_str = "    abc    "
print(my_str)

result = my_str.lstrip()   ##去除左边空格
print(result)

result = my_str.rstrip()  ##去除右边空格
print(result)

result = my_str.strip()  ##去除两边空格
print(result)

############## 运行结果 ###############

    abc    
abc    
    abc
abc

(11) rfind - 根据指定数据从右往左查找返回对应的下标

根据指定数据从右往左查找返回对应的下标,如果没有该指定数据则返回-1

my_str = "asssabc"

result = my_str.rfind("x")  ##my_str中没有x,所以会返回-1
print(result)

result = my_str.rfind("c") ##my_str中c对应的下标是6
print(result)
############## 运行结果 ###############

-1
6

(12) partition

partition: 根据指定分割符,把数据分割成三部分, 返回的是一个元组。

my_str = "abc&abc"
## 根据指定分隔符&,将字符串分割成三部分, 返回的是一个元组
result = my_str.partition("&")

print(result)
print(result,type(result))

############## 运行结果 ###############

('abc', '&', 'abc')
('abc', '&', 'abc') <class 'tuple'>

(13) splitlines - 根据换行符进行分割

my_str = "abc\nbcd\nedf"
result = my_str.splitlines()

print(result)
print(type(result))

############## 运行结果 ###############

['abc', 'bcd', 'edf']
<class 'list'>

只分割第一个换行符,后面的不分割:

my_str = "abc\nbcd\nedf"

result = my_str.split("\n", 1)  ##只分割第一个换行符
print(result)

############## 运行结果 ###############

['abc', 'bcd\nedf']

(14) isdigit - 判断字符串中是否只包含数字

my_str = "123"
# 判断字符串中是否只包含数字
result = my_str.isdigit()
print(result)

############## 运行结果 ###############

True

(15) join

根据指定字符串完成字符串的拼接,返回的是一个新的字符串。

比如,我们有一个字符串abc,我们想把它变成a,b,c,就可以用join来实现:

my_str = "abc"

# 根据指定字符串(逗号)完成对容器类型(字符串,列表,元组)中的每一个数据进行拼接,返回的是一个字符串
result = ",".join(my_str)
print(result)
print(type(result))

############## 运行结果 ###############

a,b,c
<class 'str'>

注意:使用join方法,容器类型中的每个数据都是字符串,也就是说列表中的每个数据,元组中的每个数据都要是字符串。

如果想要拼接的数据不是字符串类型,那就会报错:

my_list = ["苹果", 10086]

# 列表里的第二个数据10086不是字符串类型
result = "!".join(my_list)
print(result)

############## 运行结果 ###############

Traceback (most recent call last):
  File "C:/Users/huangjing00liang/Desktop/黑马Python45期/第03天-字符串、列表/04-代码/day03/练习.py", line 4, in <module>
    result = "!".join(my_list)
TypeError: sequence item 1: expected str instance, int found

发现报错 expected str instance, int found:想要字符串str,但发现是int

我们把列表里的内容my_list = ["苹果", 10086],全部改成字符串类型my_list = ["苹果", "10086"],就不会报错:

my_list = ["苹果", "10086"]
result = "!".join(my_list)

print(result)

############## 运行结果 ###############

苹果!10086

列表

列表最外层的表现形式是一对中括号,列表可以存储多个任意类型的数据,好比数据容器。

列表可以储存任意多个类型的数据:

my_list = [1, 3.14, "abc", True]
print(my_list, type(my_list))

############## 运行结果 ###############

[1, 3.14, 'abc', True] <class 'list'>

可以根据下标获取列表中的数据:

# 根据下标获取列表中的数据
my_list = [1, 3.14, "abc", True]
result = my_list[-2]
print(result)

############## 运行结果 ###############

abc

列表还可以结合切片使用:

# 根据下标获取列表中的数据
my_list = [1, 3.14, "abc", True]
result = my_list[2:4]
print(result)

############## 运行结果 ###############

['abc', True]

可以定义一个空列表,留着后面放数据:

my_list = []
print(my_list, type(my_list))

############## 运行结果 ###############

[] <class 'list'>

1、列表的遍历

列表的遍历可以使用for循环和while循环,推荐:for循环更加方便和简单。

使用for循环遍历列表中的每一个数据

my_list = [1, 3.14, "abc", True, [1, 3, 5]]

# 使用for循环遍历列表中的每一个数据
for value in my_list:
    # 打印每次遍历的数据
    print(value)

############## 运行结果 ###############

1
3.14
abc
True
[1, 3, 5]

使用while循环遍历列表中的每个数据

my_list = [1, 3.14, "abc", True, [1, 3, 5]]

index = 0
while index <= 4:
    # 根据下标获取对应的数据
    result = my_list[index]
    print(result)
    index += 1

############## 运行结果 ###############

1
3.14
abc
True
[1, 3, 5]

2、列表的增删改查

列表的添加,删除,修改,查看[根据下标获取数据]数据

append: 列表的末尾追加一个元素

my_list = []
print(my_list)

## append: 列表的末尾追加一个元素
my_list.append("晁盖")
print(my_list)

my_list.append("宋江")
print(my_list)

############## 运行结果 ###############

[]
['晁盖']
['晁盖', '宋江']

insert: 根据下标插入指定数据

my_list = ["晁盖", "宋江"]
print(my_list)

#在下标为0的位置插入“林冲”
my_list.insert(0, "林冲")
print(my_list)

############## 运行结果 ###############

['晁盖', '宋江']
['林冲', '晁盖', '宋江']

extend: 对指定的列表进行扩展

my_list = ["晁盖", "宋江"]
my_list1 = ["鲁智深", "李逵", "武松"]

#把my_list1里面的每一个元素(数据)添加到my_list列表中
my_list.extend(my_list1)
print(my_list)

############## 运行结果 ###############

['晁盖', '宋江', '鲁智深', '李逵', '武松']

根据下标修改数据

my_list = ["晁盖", "宋江"]
print(my_list)

##根据下标修改列表中第二个数据
my_list[1] = "及时雨宋江"
print(my_list)

############## 运行结果 ###############

['晁盖', '宋江']
['晁盖', '及时雨宋江']

根据切片修改多个数据

my_list = ["林冲", "晁盖", "鲁智深", "李逵"]
print(my_list)

## 使用切片同时修改列表中前两个数据
my_list[0:2] = ["豹子头林冲", "天王晁盖"]
print(my_list)

############## 运行结果 ###############

['林冲', '晁盖', '鲁智深', '李逵']
['豹子头林冲', '天王晁盖', '鲁智深', '李逵']

删除列表中的数据[del, remove, pop]

del 根据下标删除数据

my_list = ["林冲", "晁盖", "鲁智深", "李逵"]
print(my_list)

##删除下标是2的即第3个数据
del my_list[2]
print(my_list)

############## 运行结果 ###############

['林冲', '晁盖', '鲁智深', '李逵']
['林冲', '晁盖', '李逵']

del 根据切片删除多个数据

my_list = ["林冲", "晁盖", "鲁智深", "李逵"]
print(my_list)

del my_list[1:3]
print(my_list)

############## 运行结果 ###############

['林冲', '晁盖', '鲁智深', '李逵']
['林冲', '李逵']

remove 根据列表中的元素删除数据

my_list = ["林冲", "晁盖", "鲁智深", "李逵"]
print(my_list)

my_list.remove("鲁智深")
print(my_list)

############## 运行结果 ###############

['林冲', '晁盖', '鲁智深', '李逵']
['林冲', '晁盖', '李逵']

pop 根据下标删除数据并显示删除的数据

又想根据下标删除数据又想知道删除的数据是什么,以防删错了,这时用pop参数就能完成。

my_list = ["林冲", "晁盖", "鲁智深", "李逵"]
print(my_list)

result = my_list.pop()  ##不指定下标,默认删除最后一个元素
print(result, my_list)

############## 运行结果 ###############

['林冲', '晁盖', '鲁智深', '李逵']
李逵 ['林冲', '晁盖', '鲁智深']

根据下标查看(获取)指定数据

my_list = ["林冲", "晁盖", "鲁智深", "李逵"]
result = my_list[0:2]

print(result)

############## 运行结果 ###############

['林冲', '晁盖']

3、in 和 not in 结合列表使用

in: 判断指定数据是否在列表里面

# 存储多个用户的姓名
my_list = []

for _ in range(3):
    name = input("请输入您添加姓名:")
    my_list.append(name)

print(my_list)

# 判断是否有要查找的数据
search_name = input("请输入您要查询的姓名:")

result = search_name in my_list
if result:
    print("找到了这个人")
else:
    print("没有找到该人")

############## 运行结果 ###############

请输入您添加姓名:张三
请输入您添加姓名:李四
请输入您添加姓名:王五
['张三', '李四', '王五']
请输入您要查询的姓名:黄晶
没有找到该人

以上操作就是将输入的三个用户名:'张三', '李四', '王五' ,存放在列表my_list,然后使用 in 结合列表查找指定用户是否在列表里。

  • not in : 判断指定数据不在列表里面
name_list = ["A", 1, 3.14]

# 3.16 不在指定列表中
result = 3.16 not in name_list
print(result)

############## 运行结果 ###############

True

4、index 和 count 方法结合列表使用

index: 根据指定数据在列表中获取数据对应的下标

my_list = ["曹操", "荀彧", "贾诩"]

# 返回指定数据所对应的下标
result = my_list.index("荀彧")
print(result)

############## 运行结果 ###############

1

count: 统计指定数据在列表中出现的次数

my_list = ["曹操", "荀彧", "贾诩", "马忠", "孙权", "马忠"]

# 统计指定数据在列表中出现的次数
result = my_list.count("马忠")
print(result)

############## 运行结果 ###############

2

4、reverse 和 sort 方法结合列表使用

reverse:将列表反转

my_list = [1, 3, 2, 4]
print(my_list)

# 列表反转
my_list.reverse()
print(my_list)

############## 运行结果 ###############

[1, 3, 2, 4]
[4, 2, 3, 1]

注意:reverse方法没有提供返回值,查看数据直接使用之前的变量即可
所以如果使用一个新的变量放reverse反转后的结果就会返回空None

my_list = [1, 3, 2, 4]
print(my_list)

##`reverse`方法没有返回值
result = my_list.reverse()
print(result)

############## 运行结果 ###############

[1, 3, 2, 4]
None

sort :将列表进行排序,默认从小到大 -> 升序

my_list = [1, 3, 2, 4]
print(my_list)

my_list.sort()
print(my_list)

############## 运行结果 ###############

[1, 3, 2, 4]
[1, 2, 3, 4]

对列表里面的内容先排序再反转:

my_list = [1, 3, 2, 4]
print(my_list)

# 排序,默认从小到大 -> 升序
my_list.sort()
print(my_list)

# 对排序后的数据进行反转
my_list.reverse()
print(my_list)

############## 运行结果 ###############

[1, 3, 2, 4]    ##自己定义的列表
[1, 2, 3, 4]    ##排序后的结果
[4, 3, 2, 1]    ##对排序后的结果再进行反转

5、列表的嵌套

列表嵌套:在一个列表里面再次使用一个列表

city_list = []

# 南方城市列表
south_list = ["上海", "深圳", "广州"]
# 北方城市列表
north_list = ["北京", "天津", "济南"]

# 添加数据
city_list.append(south_list)
city_list.append(north_list)

print(city_list)

############## 运行结果 ###############

[['上海', '深圳', '广州'], ['北京', '天津', '济南']]

上面就是在一个大列表city_list里,嵌套着两个子列表:south_listnorth_list

提取大列表中的子列表:
city_list = [['上海', '深圳', '广州'], ['北京', '天津', '济南']]
north_list = city_list[1]
print(north_list)

############## 运行结果 ###############

['北京', '天津', '济南']
提取大列表中子列表中元素:

比如,我想把列表city_list = [['上海', '深圳', '广州'], ['北京', '天津', '济南']]中的天津取出来:

city_list = [['上海', '深圳', '广州'], ['北京', '天津', '济南']]

##取大列表中的子列表中的元素
city_name = city_list[1][1]
print(city_name)

############## 运行结果 ###############

天津

列表的应用

思考:一个学校,有3个办公室,现在有8位老师等待工位的分配,请编写程序,完成随机的分配

#导入模块random,它可以随机产生数字
import random

# 1. 三个办公室,办公室是可以容纳老师的,所以每一个办公室就是一个小列表
# my_list1 = []
# my_list2 = []
# my_list3 = []

# 办公室列表,里面的每个元素表示一个办公室,每个办公室还是一个列表
office_list = [[], [], []]

# 2. 8位老师,可以定义一个老师列表,存储8位老师
teacher_list = ["刘老师", "王老师", "郭老师", "马老师", "牛老师", "杨老师", "朱老师", "侯老师"]

# 3. 依次获取老师列表中的每一位老师,然后把老师随机分配到指定办公室
for teacher in teacher_list:

    # 生产随机数字,随机数字就是办公室的下标
    index = random.randint(0, 2)
    print(teacher, index)

    # 根据生产的下标获取对应的办公室
    office = office_list[index]

    # 把老师添加到随机的办公室里面
    office.append(teacher)

# 查看办公室信息
print(office_list)

############## 运行结果 ###############

刘老师 1
王老师 1
郭老师 1
马老师 2
牛老师 1
杨老师 1
朱老师 0
侯老师 0
[['朱老师', '侯老师'], ['刘老师', '王老师', '郭老师', '牛老师', '杨老师'], ['马老师']]

再思考:请优化第一步的代码使我们可以查看每个办公室的信息

import random

# 1. 三个办公室,办公室是可以容纳老师的,所以每一个办公室就是一个小列表
# my_list1 = []
# my_list2 = []
# my_list3 = []

# 办公室列表,里面的每个元素表示一个办公室,每个办公室还是一个列表
office_list = [[], [], []]

# 2. 8位老师,可以定义一个老师列表,存储8位老师
teacher_list = ["刘老师", "王老师", "郭老师", "马老师", "牛老师", "杨老师", "朱老师", "侯老师"]

# 3. 依次获取老师列表中的每一位老师,然后把老师随机分配到指定办公室
for teacher in teacher_list:

    # 生产随机数字,随机数字就是办公室的下标
    index = random.randint(0, 2)

    # 根据产生的下标获取对应的办公室
    office = office_list[index]

    # 把老师添加到随机的办公室里面
    office.append(teacher)

# 查看办公室信息
print(office_list)

num = 1
for office in office_list:
    # 查看每一个办公室,每个办公室是一个列表

    # 记录办公室老师的个数
    count = 0
    for _ in office:
        count += 1

    print("第%d个办公室总人数为:%d人" % (num, count))

    # 遍历办公室,获取每一个老师信息
    for teacher in office:
        # 查看每一个老师的信息
        print(teacher)

    num += 1

############## 运行结果 ###############

[['王老师', '杨老师'], ['刘老师', '郭老师', '朱老师'], ['马老师', '牛老师', '侯老师']]
第1个办公室总人数为:2人
王老师
杨老师
第2个办公室总人数为:3人
刘老师
郭老师
朱老师
第3个办公室总人数为:3人
马老师
牛老师
侯老师

不管是读研那会儿还是现在工作的时候,总感觉自己不会的东西好多呀,必须要学的东西有好多,自己想学的东西又有好多,当发现这些东西短期之内不可能掌握的时候就很沮丧,这就是所谓的知识焦虑症吧,生怕别人学习成长了自己没有,别人知道我不知道,别人进步了我没有进步!
slowly,inner peace
该你我会的,该我掌握的,只要我恋恋不忘,必有回响~~~

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,313评论 6 496
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,369评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,916评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,333评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,425评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,481评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,491评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,268评论 0 269
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,719评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,004评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,179评论 1 342
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,832评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,510评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,153评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,402评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,045评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,071评论 2 352

推荐阅读更多精彩内容