一、元组

另一种有序列表叫元组:tuple。tuple和list非常类似,但是tuple一旦初始化就不能修改,比如同样是列出同学的名字:

# Author:Tim Gu
tuple = ("Tim",'Jack','mike')

  元组元素不可被修改,只读。不过有一种情况是内嵌列表的时候,列表内的元素可修改

# Author:Tim Gu
tuple = ("Tim",'Jack','mike',['john','tom'])
print(tuple)
tuple[3][1] = 'mary'
print(tuple)
>>>
('Tim', 'Jack', 'mike', ['john', 'tom'])
('Tim', 'Jack', 'mike', ['john', 'mary'])

二、字符串

 输入时的空格处理: 

# Author:Tim Gu
username = input('user:')
if username.strip() == 'Tim': #去除输入时的空格
print("welcome")

  输出:

user:          Tim
welcome

  字符串的拆分与合成:

names = 'Tim,jack,rain'
name2 = names.split(",") #拆分
print(name2)
print(",".join(name2)) #组合
>>>
['Tim', 'jack', 'rain']
Tim,jack,rain

  判断字符串有没有空格

# Author:Tim Gu
name = 'Tim Gu'
if '' in name:
print('' in name)
>>>True

  字符串的格式化:format()

msg = "Hello, {name}, it's been a long {age} since time sopke..."
msg2 = msg.format(name='Tim',age=30)
print(msg2)
>>>
Hello, Tim, it's been a long 30 since time sopke...

  

msg2 = "hahaha{0}, ddd{1}"
print(msg2.format("Tim",33))
>>>
hahahaTim, ddd33

  字符串切片

name = 'tim gu'
print(name[1:3]) #打印序列字符
print(name.center(40,'-')) #填满40个字符
print(name.find('m')) #搜索字符串中的字符,返回的第一个找到的值的索引,没有找到返回-1
print(name.find('b'))
>>>
im
-----------------tim gu-----------------
2
-1

  判断输入是否数字

age = input('input you age:')
if age.isdigit(): #判断输入是否是数字
age = int(age)
else:
print('Invalid data type')
>>>
age = input('input you age:')
if age.isdigit(): #判断输入是否是数字
age = int(age)
else:
print('Invalid data type')

 判断输入是否包含特殊字符

 

name = 'Timsjl4'
print(name.isalnum())
>>>
True

  字符特殊判断

name = 'Timsjl4'
print(name.endswith('jl4')) #判断是否jl4结尾
print(name.startswith('Tim')) #判断是否Tim开头
print(name.upper()) #大写
print(name.lower()) #小写
>>>
True
True
TIMSJL4
timsjl4

三、运算:

  运算符:

  + 加

  - 减

  * 乘

  / 除

  ** 幂

  % 取摸--返回除法的余数

  // 取整数---返回商的整数

  比较运算:

  == 等于

  != 不等于

  >= 大于等于

  <=小于等于

  > 大于

  < 小于

  赋值运算:

  = 赋值

  +=加法赋值

  -=减法赋值

  *=乘法赋值

  /=除法赋值

  %=取模赋值

  **=幂赋值

  //取整除赋值

  

  逻辑运算:

  and 与---条件全为真返回True

  or 或 -----条件有一个为True,返回True

  not 布尔非

  分身运算:

  is 判断两个标识符是否引用自一个对象

  is not 判断两个标识符是不是发引用不同对象

  位运算:

  & 按位与运算符

  | 按位或运算符

  ^ 按位异或运算符

  ~ 按位取反运算符

  << 左移动运算符

  >> 右移动运算符

四、字典

  Python内置了字典:dict的支持,dict全称dictionary,在其他语言中也称为map,使用键-值(key-value)存储,具有极快的查找速度。

  字典中的key必须是唯一的。

id_db = {
9527:{
'name':'Tim',
'age':22,
'addr':'ShangHai'
},
9520:{
'name':'Jack',
'age':23,
'addr':'SuZhou'
},
9531:{
'name':'Mike',
'age':30,
'addr':'NanJing'
}
}
print(id_db) id_db[9527]['name'] = 'jeson' #修改key
print(id_db[9527]) id_db[9531]['wife_qq'] = 59594399 #增加key和值
print(id_db[9531]) del id_db[9520]['addr'] #删除key和值
print(id_db[9520]) id_db[9527].pop('addr') #删除key和值 等同于上面的del
print(id_db[9527])

输出:

{9520: {'age': 23, 'name': 'Jack', 'addr': 'SuZhou'}, 9531: {'age': 30, 'name': 'Mike', 'addr': 'NanJing'}, 9527: {'age': 22, 'name': 'Tim', 'addr': 'ShangHai'}}
{'age': 22, 'name': 'jeson', 'addr': 'ShangHai'}
{'age': 30, 'name': 'Mike', 'wife_qq': 59594399, 'addr': 'NanJing'}
{'age': 23, 'name': 'Jack'}
{'age': 22, 'name': 'jeson'}

  获取值:get()

# Author:Tim Gu
id_db = {
9527:{
'name':'Tim',
'age':22,
'addr':'ShangHai'
},
9520:{
'name':'Jack',
'age':23,
'addr':'SuZhou'
},
9531:{
'name':'Mike',
'age':30,
'addr':'NanJing'
}
}
print(id_db)
v = id_db.get(9531) #一般使用get获取值
#v = id_db[9531]#不建议使用这个
print(v)

  输出:

{9520: {'name': 'Jack', 'addr': 'SuZhou', 'age': 23}, 9531: {'name': 'Mike', 'addr': 'NanJing', 'age': 30}, 9527: {'name': 'Tim', 'addr': 'ShangHai', 'age': 22}}
{'name': 'Mike', 'addr': 'NanJing', 'age': 30}

  

  update()

# Author:Tim Gu
id_db = {
9527:{
'name':'Tim',
'age':22,
'addr':'ShangHai'
},
9520:{
'name':'Jack',
'age':23,
'addr':'SuZhou'
},
9531:{
'name':'Mike',
'age':30,
'addr':'NanJing'
}
} dist2 = {
9527:{
'name':'zhangsan',
'age':10,
'addr':'JiangXi'
}
}
print(id_db)
id_db.update(dist2)
print(id_db)

输出: 如果存在相同的key值,即覆盖。如不存在,则新建

{9520: {'age': 23, 'addr': 'SuZhou', 'name': 'Jack'}, 9531: {'age': 30, 'addr': 'NanJing', 'name': 'Mike'}, 9527: {'age': 22, 'addr': 'ShangHai', 'name': 'Tim'}}
{9520: {'age': 23, 'addr': 'SuZhou', 'name': 'Jack'}, 9531: {'age': 30, 'addr': 'NanJing', 'name': 'Mike'}, 9527: {'age': 10, 'addr': 'JiangXi', 'name': 'zhangsan'}}

  

  返回字典中的key或值,判断KEY是否存在:

# Author:Tim Gu
id_db = {
9527:{
'name':'Tim',
'age':22,
'addr':'ShangHai'
},
9520:{
'name':'Jack',
'age':23,
'addr':'SuZhou'
},
9531:{
'name':'Mike',
'age':30,
'addr':'NanJing'
}
} print(id_db)
print(id_db.values())
print(id_db.keys())
print(9527 in id_db)

  输出:

{9520: {'addr': 'SuZhou', 'age': 23, 'name': 'Jack'}, 9531: {'addr': 'NanJing', 'age': 30, 'name': 'Mike'}, 9527: {'addr': 'ShangHai', 'age': 22, 'name': 'Tim'}}
dict_values([{'addr': 'SuZhou', 'age': 23, 'name': 'Jack'}, {'addr': 'NanJing', 'age': 30, 'name': 'Mike'}, {'addr': 'ShangHai', 'age': 22, 'name': 'Tim'}])
dict_keys([9520, 9531, 9527])
True

  set.default():

# Author:Tim Gu
id_db = {
9527:{
'name':'Tim',
'age':22,
'addr':'ShangHai'
},
9520:{
'name':'Jack',
'age':23,
'addr':'SuZhou'
},
9531:{
'name':'Mike',
'age':30,
'addr':'NanJing'
}
} print(id_db.setdefault(9527)) #取一个key
print(id_db.setdefault(9333,'dddd')) #如果不存在,新增一个默认的key和值

  输出:

{'age': 22, 'addr': 'ShangHai', 'name': 'Tim'}
dddd

随机删除:popitem()

# Author:Tim Gu
id_db = {
9527:{
'name':'Tim',
'age':22,
'addr':'ShangHai'
},
9520:{
'name':'Jack',
'age':23,
'addr':'SuZhou'
},
9531:{
'name':'Mike',
'age':30,
'addr':'NanJing'
}
} print(id_db.popitem()) #随机删除一组数据
print(id_db)

  输出:

(9520, {'name': 'Jack', 'addr': 'SuZhou', 'age': 23})
{9531: {'name': 'Mike', 'addr': 'NanJing', 'age': 30}, 9527: {'name': 'Tim', 'addr': 'ShangHai', 'age': 22}}

  

  字典转化为元组:items()

# Author:Tim Gu
id_db = {
9527:{
'name':'Tim',
'age':22,
'addr':'ShangHai'
},
9520:{
'name':'Jack',
'age':23,
'addr':'SuZhou'
},
9531:{
'name':'Mike',
'age':30,
'addr':'NanJing'
}
} print(id_db.items())
>>>
dict_items([(9520, {'name': 'Jack', 'age': 23, 'addr': 'SuZhou'}), (9531, {'name': 'Mike', 'age': 30, 'addr': 'NanJing'}), (9527, {'name': 'Tim', 'age': 22, 'addr': 'ShangHai'})])

  

  字典的循环:

# Author:Tim Gu
id_db = {
9527:{
'name':'Tim',
'age':22,
'addr':'ShangHai'
},
9520:{
'name':'Jack',
'age':23,
'addr':'SuZhou'
},
9531:{
'name':'Mike',
'age':30,
'addr':'NanJing'
}
} for key in id_db:
print(key,id_db[key])

  输出:

9520 {'age': 23, 'name': 'Jack', 'addr': 'SuZhou'}
9531 {'age': 30, 'name': 'Mike', 'addr': 'NanJing'}
9527 {'age': 22, 'name': 'Tim', 'addr': 'ShangHai'}

五、集合 set

set和dict类似,也是一组key的集合,但不存储value。由于key不能重复,所以,在set中,没有重复的key。

  创建一个set

# Author:Tim Gu

s = set({1,3,4,5})
s2 = {1,2,3,4}
print(type(s))
print(s)
print(type(s2))
print(s2)
>>>
<class 'set'>
{1, 3, 4, 5}
<class 'set'>
{1, 2, 3, 4}

 s2其实是调用了set()的构造方法

 列表转化集合:

li = [11,22,11,22]
s1 = set(li)
print(s1)

  输出:

{11, 22}

  注意:集合是没有重复值的

  集合添加元素:

se = {1,2,5,6,4}
se.add(3)
print(se)
>>>
{1, 2, 3, 4, 5, 6}

  集合删除元素:

se = {1,2,5,6,4}
se.remove(5) #删除,如果5不存在,报错
se.discard(2)#删除,如果2不存在,不报错
print(se)
>>>
{1, 4, 6}

  集合是无序的无重复的元素的集合,所以两个set可以做交集、并集等操作:

se1 = {1,2,5,6,4}
se2 = {5,6,8,3,44} print(se1&se2)
print(se1|se2)
>>>
{5, 6}
{1, 2, 3, 4, 5, 6, 8, 44}

  差集:  

s1 = {11,22,33}
s2 = {22,33,44}
s4 = {33,44,55}
s3 = s1.difference(s2)
print(s3) #s1中存在,s2中不存在 s3 = s1.symmetric_difference(s2) #d对称差集
print(s3) s1.difference_update(s2) #将s1更新为s1和s2的差集
print(s1)

  输出:

{11}
{11, 44}
{11}
s1 = {11,22,33}
s2 = {22,33,44} s1.symmetric_difference_update(s2) #将s1更新为s1和s2的对称差集
print(s1)
>>>
{11, 44}

  

  pop移除:

s1 = {11,22,33}
ret = s1.pop() #因集合是无序的,pop()会随机移除元素,将移除的元素赋给ret
print(s1)
print(ret)
>>>
{11, 22}
33

  并集:

s1 = {11,22,33}
s2 = {22,33,44}
s3 = s1.union(s2)
print(s3)
>>>
{33, 22, 11, 44}

  update()

s1 = {11,22,33}
li = [11,22,3,11,2]
s1.update(li)
print(s1) s = 'tim'
s1.update(s)
print(s1)
>>>
{3, 33, 2, 11, 22}
{33, 2, 3, 't', 'i', 11, 'm', 22}

   第二周练习:完美购物车

要求:

购物车:
用户启动程序后打印商品列表
允许用户选择购买商品
允许用户不断地购买各种商品
购买时检测 余额是否足够,如果足够,直接扣款 否则打印余额不足
允许用户主动退出程序,退出时打印已购商品列表

# Author:Tim Gu

for i in range(3):
salary = input('Input your salary:')
if salary.isdigit():
salary = int(salary)
break
else:
print('Invaild data type...')
if i == 2:
print('Wrong!')
continue welcome_msg = 'Welcome to Tim Shopping mall'.center(50, '-')
print(welcome_msg) exit_flag = False
product_list = [
('Iphone',5888),
('Mac Air',8000),
('mac pro',9000),
('xiaomi 2',19.2),
('Coffer',30),
('Tesla',820000),
('Bike',700),
('Cloth',200)
] shop_car = []
while exit_flag != True:
print('product list'.center(50,'-'))
for item in enumerate(product_list):#枚举元组
index = item[0]
p_name = item[1][0]
p_price = item[1][1]
print(index,p_name,p_price)
user_choice = input('[q=quit,c=check]What do you watn to buy?:')
if user_choice.isdigit():#肯定是选择商品
user_choice = int(user_choice)
if user_choice < len(product_list):
p_item = product_list[user_choice]
if p_item[1] <= salary: #资金够买
shop_car.append(p_item)
salary -= p_item[1]
print('Added [%s] into shop car,you current balance is \033[31;1m[%s]\033[0m'%(
p_item[0],salary))
else:
print("Your balance is [%s],cannot afford this..."%salary)
elif user_choice == 'q' or user_choice == 'quit':
print("purchased products as below".center(40,'*'))
for item in shop_car:
print(item)
print("END".center(40,'*'))
print("Your balance is [%s] last"%salary)
exit_flag = True
elif user_choice == 'c' or user_choice == 'check':
print("purchased products as below".center(40, '*'))
for item in shop_car:
print(item)
print("END".center(40, '*'))
print("Your balance is \033[41;1m[%s] last\033[0m" % salary)

  作业需求:

  

作业需求: 1.优化购物程序,购买时允许用户选择购买多少件

2.允许多用户登陆,下一次登录后,继续按上次的余额继续购买(可以充值)

3.允许多户查看之间的购买记录(记录要显示商品购买时间)

4.商品列表分级展示,比如 第一层菜单: 1.家电类 2.衣服 3.手机类 4.车类

随便选择一个,比如车类,进入第2层

1.BMW X3 300000

2.AUDI Q5 350000

3.pasate 333335

4 tesla model_3 430000

5.tesla model_s 8888888

5.显示已购买商品时,如果有重复的商品,不打印多行,而是在一行展示

id  p_name        num     total_price

1.  TeslaModelS    2        35000000

2.  coffee             4     10000

  

Python学习之旅--第二周--元组、字符串、运算、字典的更多相关文章

  1. Python学习之旅--第二周--python基础

    一.什么是pyc? 1.Python是解释性语言,那么.pyc是什么文件? 2.解释性语言和编译型语言区别:    计算机是不能够识别高级语言的,所以当我们运行一个高级别语言程序时,就需要一个&quo ...

  2. Python 学习日记(第二周)

    从这周开始我就正式学习Python 语言了.以后每周都会有一篇有关于学习Python的见闻与大家分享! Python的安装 学习的第一步首先要有一个运行的环境.所以接下来介绍一下安装的步骤. 通过Py ...

  3. Python学习之旅--第一周--初识Python

    一:Python是一种什么样的语言? 1.语言的分类: a.编译型语言和解释性语言: 通常所说的计算机语言分为编译型和解释型语言.编译型语言典型的如C,C++,通常在程序执行之前必须经由编译器编译成机 ...

  4. 老男孩python学习自修【第二天】字符串用法

    实时处理增量日志最佳实践 主要使用f.seek()和f.tell()实现 字符串处理函数: s.find(substr, start, end) 查找子字符串,找不到则返回-1,找到则返回对应的索引 ...

  5. 180分钟的python学习之旅

    最近在很多地方都可以看到Python的身影,尤其在人工智能等科学领域,其丰富的科学计算等方面类库无比强大.很多身边的哥们也提到Python非常的简洁方便,比如用Django搭建一个见得网站只需要半天时 ...

  6. python学习6—数据类型之集合与字符串格式化

    python学习6—数据类型之集合与字符串格式化 1. 使用id()可以查看一个变量的内存地址: name = 'alex' id(name) 2. 进制转换 十进制转换为二进制等: a = 10 # ...

  7. 学习HTML5的第二周

    ---恢复内容开始--- 这是我学习H5的第二周,在本周,我独立完成了一个网站的首页和一个二级页,虽然在做网页的时候我遇到了许多问题,但我自己想办法解决了其中的大部分,只留下了一小部分没有头绪的问题等 ...

  8. 红帽学习笔记[RHCSA] 第二周

    目录 红帽学习笔记[RHCSA]第二周 环境 第七课[网络配置相关] 在Vmware中添加网卡 将网卡添加到虚拟机上 关于网卡命名规则 配置网络 网络配置命令总结 更改hostname 关于SSH的一 ...

  9. Python学习系列(五)(文件操作及其字典)

    Python学习系列(五)(文件操作及其字典) Python学习系列(四)(列表及其函数) 一.文件操作 1,读文件      在以'r'读模式打开文件以后可以调用read函数一次性将文件内容全部读出 ...

随机推荐

  1. notes/Set up development environment on windows

    恰好前几天买了个新笔记本, 15存 sony vaio, 终于从mac回到了windows. 不过作为(曾经的)*nix追随者, 没有bash真是寸步难行, 幸好windows8.x有了super s ...

  2. Django入门实践(三)

    Django入门实践(三) Django简单应用 前面简单示例说明了views和Template的工作过程,但是Django最核心的是App,涉及到App则会和Model(数据库)打交道.下面举的例子 ...

  3. 算法线性编程珠玑读书笔记之----->使用线性算法求解连续子序列的最大和

    这段时间笔者几篇文章介绍了改算法线性的文章. 关联文章的地址 这个算法我在我的博客里应用动态规划做过,详细实现请参阅我的dp板块,下面给出书上最快的算法,时间复杂度为O(n),称之为线性算法. #in ...

  4. windows下练习linux shell

    <---开始学习linux---记录一下---路漫漫其修远兮---加油吧---萌萌达> 使用软件:Cygwin  下载地址(免安装版):链接: http://pan.baidu.com/s ...

  5. web开发技术中Servlet技术的概述

    1.servlet是什么:servlet是一个位于服务器端的java应用程序它可以像jsp一样,直接输出信息 servlet类必须继承HttpServlet类,否则,不能称为serlvet servl ...

  6. mysql建立、删除索引及使用

    同步发布:http://www.yuanrengu.com/index.php/2017-01-13.html 一.索引的作用 一般的应用系统,读写比例在10:1左右,而且插入操作和一般的更新操作很少 ...

  7. python数据类型以及模块的含义

    print(sys.path) #打印环境变量 print(sys.argv) #打印相对路径 print(sys.argv[1]) #打印对应的参数 1.在python最上有时候会导入os模块,表示 ...

  8. 多目标遗传算法 ------ NSGA-II (部分源码解析)介绍

    NSGA(非支配排序遗传算法).NSGA-II(带精英策略的快速非支配排序遗传算法),都是基于遗传算法的多目标优化算法,是基于pareto最优解讨论的多目标优化. 在官网: http://www.ii ...

  9. 转载一篇nm命令使用的文章,虽然没用用这个方法解决但是文章很好

    http://blog.csdn.net/acs713/article/details/13505931

  10. IOS数据库操作SQLite3使用详解(转)

    iPhone中支持通过sqlite3来访问iPhone本地的数据库.具体使用方法如下1:添加开发包libsqlite3.0.dylib首先是设置项目文件,在项目中添加iPhone版的sqlite3的数 ...