Python基础-day06

list

​ 字符串操作

​ 字典操作

​ list操作

字符串操作

my_str = "j2hdjA mK"

# 转换成大写
res = my_str.upper()
print(res)

# 转小写
res1 = my_str.lower()
print(res1)
# 将字符串首字母大写
res3 = my_str.capitalize()
print(res3)

# 将字符串每个单词首字母大写
res4 = my_str.title()
print(res4)

# 字符串的切分 2对应的参数位置 表示的是切分几次
res5 = my_str.split(" ", 2)
print(res5)

# 去掉字符串左侧指定符号
res9 = my_str.lstrip("ss")
print(res9)
print(my_str)

# 去掉字符串右侧指定符号
res10 = my_str.rstrip("s")
print(res10)

# 同时去掉两侧的字符
res11 = my_str.strip(" ")
print(res11)

# 字符串的连接
res6 = " ".join(res5)
print(res6)

# 左对齐
my_str = "we"
res11 = my_str.ljust(4, '-')
print(res11)

# 右对齐
res12 = my_str.rjust(4, '+')
print(res12)

#居中 如果字符串长度小于我们指定的长度,默认是用空格 然后也可以指定填充的字符
res13 = my_str.center(5, "ww")
print(res13)

# 替换 replace(‘你要替换的字符串’, ‘用什么替换’, 替换多少个)
res14 = my_str.replace("h", '8')
print(res14)
res15 = my_str.replace('s', '6', 2) 解释:‘s’ 是我要替换的 用‘6’来替换, 2说的是替换的个数
print(res15)

# zfill 将字符串右对齐 然后位数不够用0补 注意当指定位数小于字符串长度 使用的是字符串长度本身
my_str = "aq1"
res16 = my_str.zfill(2)

# 大写转小写 小写转大写
my_str = "AcjjU"
res17 = my_str.swapcase()
print(res17)

# 切分 按照第一个匹配的字符去切分 保留指定切分的切分字符,  变成元组,元组第一项是切分字符左侧的内容 第二项是你指定切分字符 第三项是切分字符右侧的内容
res18 = my_str.partition("c")

# 和partition类似 只是匹配切分字符 是从右开始
res19 = my_str.rpartition("c")
print(res19)

# 统计字符出现的个数
res20 = my_str.count("l", 起始值, 结束值)
print(res20)

编码解码

计算机存储数据使用的是二进制

​ gbk

​ 一个中文字符 占2个16进制字节

​ gb2312

​ 一个中文字符 占2个16进制字节

​ utf-8 -->unicode

​ 一个中文字符 占3个16进制字节

​ a=”张三“

​ 使用encode来进行编码

​ res22 = a.encode("utf-8")

​ 使用decode来进行解码

​ res23 = res22.decode("utf-8")

​ 注意;解码是针对于字节来说的

格式化输出

# "string%d" % age
age = 18
money = 100000000
print("我的年纪是%d" % age)
# 多个值的情况 “字符串%d呵呵呵%d” % (age, money)
print("我的年纪是%d,我的存款%d津巴布韦币" % (money, money))
#

需要注意的是 %后的变量是依次赋值给你的占位符

%d  整数
%f  float类型  默认输出小数部分是6位 如果想保留自己制定长度 那么使用%.位数
%s  字符串

使用format

name = "张三"
age = 30
weight = 80.2
my_str1 = "我叫{}, 我今年{}岁, 我体重是{}".format(name, age, weight)

第二种 指定下标占位

# 指定下标占位
my_str2 = "我叫{0}, 我今年{1}岁, 我体重是{2}, 我哥也叫{0}".format(
    name, age, weight
)
print(my_str2)
#
params = [name, age, weight] ---》(name, age, weight)
my_str3 = "我叫{0}, 我今年{1}岁, 我体重是{2}, 我哥也叫{0}".format(*params)
print(my_str3)

第三种 指定占位名字

my_str4 = "我叫{u_name}, 我今年{u_age}岁, 我体重是{u_weight}, 我哥也叫{u_name}".format(
    u_name=name, u_age=age, u_weight=weight
)
print(my_str4)

params_dict = {"u_name": name, "u_age": age, "u_weight": weight}

my_str5 = "我叫{u_name}, 我今年{u_age}岁, 我体重是{u_weight}, 我哥也叫{u_name}".format(
    **params_dict
)
print(my_str5)

数据类型

dict操作

my_dict = {"name":"lucy", "age": 20}

clear() 清空字典

fromkeys  生成一个新的字典 第一个参数 是指定你的key序列, 第二个参数是字典对应的value
  my_dict1 = {}
  res = my_dict1.fromkeys([1,2,3], "j")

items() 将字典转成列表嵌套元组的形式
    res = my_dict.items()
    print(res)
    打印的结果如下:
    dict_items([('name', 'lucy'), ('age', 20)])
keys() 
    获取字典所有的键
values()
    获取字典所有的值
    
pop(key)
    弹出一个key对应的value值, 原来字典将会删除掉对应的键值对
    res = my_dict.pop("name")
    print(res)
    print(my_dict)
popitem()
    弹出字典的一项 然后原来的字典 将会移除掉对应键值对
    
setdefault(key, value)
    在原来字典的基础上 添加一个键值对 如果key 存在将不会设置成功, 如果key不存在 那么才生效,
    函数操作的返回结果 如果key存在是 原来这个key对应value 否则返回的是你设置的value
    res = my_dict.setdefault("name", 'lili')
    print(res, my_dict)
    res = my_dict.setdefault("samll_name", 'lili')
    print(res, my_dict)
update(字典)
    在原来字典的基础上追加新的键值对 如果key有相同的那么 更新原来字典key所对应的value
    my_dict2 = {"money":10, "hobby":[1,2,34], 'name':"bob"}
    my_dict.update(my_dict2)
    print(my_dict)

list操作

count() 计数 来统计列表元素出现的次数

extend(另一个列表) 将另一个list追加到调用列表后边

a = ["abc", "abcd", "e", "as"]


b = [1,2,4]

a.extend(b) 将b列表添加到a里

index(要找的元素, 找的起始值,找末位值)

​ 返回你要查找元素的下标(返回的是匹配到的第一个元素) 如果元素不在列表里 那么他将会报一个ValueError

res = a.index("absssc",2, len(a))
print(res)

insert(要插入的位置,要插入的元素)

​ 当给定的index较大的时候 那么是追加到数组的最后

a.insert(10002, "9")
print(a)

pop(需要弹出的下标)

​ 返回弹出的元素,在原来的列表删除对应下标的元素

a.pop(0)
print(a)

remove(要移除的元素) 不返回 删除的元素(删除的是他匹配的第一个)

​ 如果要移除的元素 不再列表里 那么将会报ValueError异常

res = a.remove("abc")

reverse()

​ 将列表翻转 逆序 没有返回值 而是直接影响原来这个字符串

a.reverse()

sort()

​ 排序 默认是对数组里的元素的ASCII比较

​ 如果指定了key参数(排序规则),就使用新的规则,

​ reverse 来设置是不是降序排列 默认Flase是升序排列

指定排序的规则
def str_len(my_str):
    return len(my_str)
排序
res = a.sort(key=str_len, reverse=True)
print(res, a)

将函数作为参数使用

def my_function(fun, value):
    res = fun(value)
    print(res)

将abs函数 当成参数使用
my_function(abs, -2)

任务

​ 了解冒泡排序 选择排序 插入排序

​ 了解时间复杂度 空间复杂度

​ 完善学生管理系统增加操作如下

​ 5 操作是 求学生的平均成绩 字典values函数

​ 6 求不及格学生 60分一下

​ 7 求最高分和最低分

​ 8 退出

知识点

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

推荐阅读更多精彩内容