http://www.cnblogs.com/yuanchenqi/articles/5782764.html
一、变量
1、定义:变量用于存储要在计算机程序中引用和操作的信息。他们还提供了一种以描述性名称标注数据的方法,所以我们的程序可以被读者和我们自己更清楚地理解。将变量视为容纳信息的容器是有帮助的。它们的唯一目的是将数据标记和存储在内存中。 然后可以在整个程序中使用此数据。
2、声明变量:name="alex"
上述代码声明了一个变量,变量名为: name,变量name的值为:"Alex Li"
3、变量定义规则:
- 变量名只能是 字母、数字或下划线的任意组合
- 变量名的第一个字符不能是数字
- 以下关键字不能声明为变量名
['and', 'as', 'assert', 'break', 'class', 'continue', 'def', 'del', 'elif', 'else', 'except', 'exec', 'finally', 'for', 'from', 'global', 'if', 'import', 'in', 'is', 'lambda', 'not', 'or', 'pass', 'print', 'raise', 'return', 'try', 'while', 'with', 'yield']
4、变量的赋值
二、缩进
缩进就是控制块,官方建议空四个空格,在很多语言里都是通过大括号来实现的,但是Python是通过空格
三、注释
单行注释:#
多行注释:""" """或''' '''
四、运算符
1、算数运算符 + - * /
2、赋值运算符 = += -= *= /=
3、比较运算符 == >= <= != > < (一定是布尔值,用于循环)
4、逻辑运算符 and(与) or(或) not(非)
5、关系运算符 in not in (返回值是布尔值)
例:print(2 in [1,2,3]
True
6、位运算符
五、数据类型
1、定义:计算机顾名思义就是可以做数学计算的机器,因此,计算机程序理所当然地可以处理各种数值。但是,计算机能处理的远不止数值,还可以处理文本、图形、音频、视频、网页等各种各样的数据,不同的数据,需要定义不同的数据类型。在Python中,能够直接处理的数据类型有以下几种
所有的数据类型一定可以划分为两种:
可变数据类型:列表,字典
不可变数据类型:整形,元组,字符串
不可变数据类型如下图:
再比如:i=1(在内存中创建一个数据类型)
i=2(并不是覆盖1,而是开辟一块新的空间,写上2)
2、数字(整形,浮点型,布尔类型)
整形
Python3中整形(int)就是长整型,在2.x版本中才有区分
浮点型(float,double)
科学计数法,是为了节省空间,比如无线循环和不循环小数如果一直存在去电脑会崩溃
精度要求非常高的话使用double
例:0.000123=1.23e^(-4)
布尔值
True=1,False=0,二者可进行运算,True+False=1
3、字符串(string)
创建2种(表达式和关键字):表达式:s="zhongguo"
关键字:s=str("zhongguo")#涉及到类
字符串操作:
查找 [] [:] #序列都可以进行切片,如字符串列表元组
去空:strip()#把字符串的开头和结尾的空格和制表符还有换行符去掉,括号里可以加参数
拼接:s="hello"+"world"+"I"+"am"+"python"(拼接次数多的话,效率要低,因为字符串是不可变的,显示helloworld申请一块内存空间,然后又是helloworldI申请一段内存空间,然后又是helloworldIam申请一断内存空间,一次类推)
"".join(iterable)#数字不能拼接,不是一个类型的不能拼接,""中可以加*,空格之类的其他东西
分割:split(),正好与join相反是把字符串分割成一个列表,参数只要字符串中有的都可以加,还有最大分个数split(,)逗号后边可以规定分割次数
splitlines是以换行符为分隔符的如果末尾有 的话不会显示,但split会显示
find(找不到返回-1)
"hello world".find("l")#打印后返回2
"hello world".find("l",3)#打印后返回3
index(找不到报错)
"hello world".index("l",4)#返回后打印9
replace
"hello world".replace("world","python")#完全匹配,必须一对一匹配上
s="hello world"
print(s.replace("world","python"))------------->hello python
print(s)------------------------------------------>hello world
因为字符串是不可变的,所以hello python是开辟了一块新的空间,之前的s还是指向hello world,而后边讲到的append针对的类型是可变的,是直接对列表(只举列表这一个例子)进行修改,没有返回值,也就意味着并没有开辟新的空间,直接打印原列表即可
居中显示:print("hello world".center(50,"*"))#居中显示总共50个字符,不够的用*补上
print("hello world".ljust(50,"*"))#靠左显示,右边用*补全,总共50个字符
字符串的格式化输出:
"hello %s"%"sb"---------->print后输出hello sb
%s,给字符串占位 %d,给整形占位 %f,给浮点型数据占位,%.4f小数点后保留四位(占四位)
"hello {0},his age is {1}".format("alex",34)#按索引位对应
"hello {name},his age is {age}."format(name="wusir",age=30)#通过键值对(推荐)
"hello {name},his age is {age}."format_map({"name":"agon","age":33})#通过字典
关于数字判断:isdecimal(),isdigit(),isnumeric()--->返回True或者False
isnumeric中1,一,I,壹都可以识别
大小写:
print("hello world".capitalize())----->Hello world
print("hello world".title())------------>Hello World
print("HEllO world".casefold())------->hello world
print("HEllO world".lower())------->hello world
expandtabs
"HELLO world".expandtabs(20)更改 的空格数
zfill:
print("hello world".zfill(50))#其他位置都补0,内容右对齐
4、列表 可迭代对象,能够进行for循环的就是可迭代对象
创建:l=[1,"hello",[4,5],{"name":"egon"}]
l2=list([1,23,3])
查:切片[:]
增:append()#可以追加字符串和列表,追加到最后,只能添加一个,不能添加多个
print(l2.append("yuan"))#返回None因为列表为可变的,没有开辟新的空间,直接在原来的结果上进行了添加
extend()#可以进行多个添加,如12.extend([7,8])如果是多序列的话参数必须是列表形式
insert(2,66)#指定位置进行插入,插入的66索引值为2
删:l2.pop(1)#pop参数为索引值,返回删掉的值
l2.remove(23)#不知道索引值,通过内容删除
del 12[2]#最霸道的删除
del l2#可直接删掉列表 del l2[1,3]#可以分段删
改:l2[0]="yuan"
清空:l2.clear()#清空就是把里面的值全清空,效率低
l2=[]#(推荐)与上面的不一样,这个是把l2重新指向了一个新的地址,所以和上面的内存地址肯定不一样
计数:l2.count(3)#返回值是1,判断列表里有几个3
长度:len(l2)#返回值是3,判断l2中有几个元素
排序:sort l3=[3,1,56,34]
l3.sort()#.方法,默认reverse=False要从大到小排:l3.sort(reverse=True)
print(l3)
sorted print(sorted(l3))#函数方法
拷贝:深拷贝和前拷贝
5、字典(哈希算法可哈希就是可以进行哈希算法 反之就是不可以 可以进行哈希算法的数据就是不可变类型的,如果是不可变的,在对对象本身操作的时候,必须在内存的另外地方再申请一块区域(因为老区域#不可变#),老的区域 就丢弃了(如果还有其他ref,则ref数字减1,类似unix下的hard-link)。如果是可变的,对对象操作的时候,不需要再在其他地方申请内 存,只需要在此对象后面连续申请(+/-)即可,也就是它的address会保持不变,但区域会变长或者变短。
)无序的
Python中唯一具有映射关系的数据类型,字典的查询速率要远高于列表,好比一页一翻得找和找到对应的页码直接找页码,但是字典的存储空间较大,比列表多了一张映射表,总之,是用空间取换取时间
创建:d={"name":"alex","name":"egon"}#打印结果会以后面的结果为准,就是前边的被覆盖了,白写。键唯一且为不可变数据类型,如元组、字符串、整形
查:d["name"]
d.get("name",None)#推荐,如果字典里没有的话返回None,可以换成一些其他的东西比如False
for i in dict循环遍历的是字典的key
for i in dict:
print("%s---->%s"%(i,d[i]))#格式化输出
增:d["gao"]="luchuan"
改:d["name"]="yuan"
删:d.pop("1")#返回删掉的value值
6、集合set 两个功能:去重,关系测试。 可变数据类型
set集合内元素一定是不可变数据类型
关系测试:s1={"hello",1,2,3}
s2={1,2,("a","b")}
求并集:print(s1.union(s2))
print(s1|s2)#顺序没关系
求交集:print(s1.intersection(s2))
print(s1&s2)
求差集:print(s1.difference(s2))#s1中有的,s2中没有的
print(s1-s2)
print(s2.difference(s1))#s2中有的,s1中没有的
print(s2-s1)
求对称差集:print(s1.symmetric_difference(s2))#互相都没有的
print(s1^s2)
7、元组tuple (不能进行修改操作)
查: 切片 [:]
8、循环中的注意点
if和else、elif语句使用时需要注意一下两点:
1.else、elif为子块,不能独立使用
2.一个if语句中可以包含多个elif语句,但结尾只能有一个else语句
else在while、for循环语句中的作用
Python中,可以在while和for循环中使用else子句,它只是在循环结束之后才会被执行,如果同时使用了break语句那么else子句会被跳过。所以注意else子句和break语句不能同时使用
9、三级菜单
menu = { '北京': { '海淀': { '五道口': { 'soho': {}, '网易': {}, 'google': {} }, '中关村': { '爱奇艺': {}, '汽车之家': {}, 'youku': {}, }, '上地': { '百度': {}, }, }, '昌平': { '沙河': { '老男孩': {}, '北航': {}, }, '天通苑': {}, '回龙观': {}, }, '朝阳': {}, '东城': {}, }, '上海': { '闵行': { "人民广场": { '炸鸡店': {} } }, '闸北': { '火车战': { '携程': {} } }, '浦东': {}, }, '山东': {}, } current_layer = menu layer = [] while True: for i in current_layer: # 将当前层赋值给i print(i) choice = input(">:").strip() if not choice: continue if choice in current_layer: layer.append(current_layer) current_layer = current_layer[choice] elif choice == "b": if len(layer) != 0: current_layer = layer.pop() else: print("到顶了") elif choice == "q": exit("offer")
10、简单购物车
product_list = [["Iphone7",5800],#建立一个商品列表 ["Coffee",30], ["Gedatang",10], ["PythonBook",99], ["bike",200] ] shopping_cart = {}#建一个空字典,装东西,购物车空字典 salary = int(input("input your salary:"))#工资是数字,所以要int() while True :#当工资是数字的时候,运行循环 index = 0 for product in product_list:#从商品列表中取出商品,价格列表 print(index,product)#打印商品代号,商品和价格列表 index += 1 choice = input(">>:").strip()#选择商品对应的数字,stip后空格和Tab无效 if choice.isdigit():#判断是否为数字 choice = int(choice)#将数字转为整形 if choice >= 0 and choice < len(product_list):#商品存在,如果数字大于等于0并且小于商品列表最大数 product = product_list[choice]#取到商品 if product[1] <= salary:#判断能否买得起,product包括商品和商品价格 #买得起 if product[0] in shopping_cart:#product[0]是商品名字,[1]是商品价格 shopping_cart[product[0]][1] +=1#购物车字典,以product[0]为key,value是 else: shopping_cart[product[0]]=[product[1],1]#加入购物车,创建一条商品购买记录 salary -=product[1]#扣钱 print("已经把"+product[0]+"加入到你的购物车,您的余额还剩"+str(salary-product[1])+"元钱") else: print("买不起,产品价格是"+ str(product[1]) +"你还差"+str(product[1]-salary)+"元钱") else: print("商品不存在!") elif choice == "q": print("-----已购买商品列表-----") id_counter = 1 total_cost = 0#初始化一个总消费的变量 print("id 商品 数量 单价 总价") for key in shopping_cart: print("%s %s %s %s %s"%(id_counter, key, shopping_cart[key][1], shopping_cart[key][0], shopping_cart[key][1]*shopping_cart[key][0] )) id_counter += 1 total_cost += shopping_cart[key][1]*shopping_cart[key][0] print("您的总花费为:",total_cost) print("您的余额为:",salary) print("-----end-----") break else: print("无此选项")