Python开发基础-day2

2023-01-31 00:01:29 python 开发 基础

一.python列表

list是处理和存放一组数据的列表

    用法:

    acclist.index()   调出list中内容位置

    acclist.insert()  (要插入的位置,插入的内容)  list插入内容

    acclist.remove(value)    指要删除的list中的内容(找到的第一个value)          acclist.count(‘value’) 查找list中有多少个value

    acclist[4] = ‘value’     更改某个位置的元素

    acclist.pop()         移除list中最后一个value(删除第8个用:acclist.pop(8))

    acclist.reverse()      把listz中value前后位置颠倒

    acclist.sort()     把list中value排序(先数字,在大写字母,小写字母)

    acclist.append()       方法向列表的尾部添加一个新的元素

    acclist.extend([list]) == acclist + a 只接受一个列表作为参数,并将该参数的每个元素

  列表切片:

      acclist[x:y]        截取list中元素x~y

        >>>acclist

[0, 1, 12, 14, 16, 18, 'alices', 'dong', 'sam','sam', 'shaw']

>>> acclist[4:7]

[16, 18, 'alices']

  取列表最小值:   

        >>> a = [1,200,3,600]

        >>>a.sort()

        >>> a

        [1, 3, 200,600]

        >>>min(a)

        1

        >>>max(a)

        600

  元素的引用:

  a、范围引用:基本样式[下限:上限:步长]

        >>>print s1[:5]             # 从开始到下标4 (下标5的元素不包括在内)

        >>>prints1[2:]             # 从下标2到最后

        >>>prints1[0:5:2]          # 从下标0到下标4 (下标5不包括在内),每隔2取一个元素(下标为0,2,4的元素)

        >>>prints1[2:0:-1]         # 从下标2到下标1

b、尾部元素引用

        >>>print s1[-1]             # 序列最后一个元素

        >>>prints1[-3]             # 序列倒数第三个元素

c、字符串是一种特殊的元素,因此可以执行元组的相关操作

        >>> str = 'abcdef'

        >>> printstr[2:4]

d、如果s1[0:-1], 那么最后一个元素不会被引用(即,不包括上限元素本身)

        >>> s1 = (2, 1.3, 'love', 9, 12, False)

        >>> prints1[0:-1]

        (2, 1.3, 'love',9, 12)

        例如:(取0-10之间偶数/奇数)

        >>> c= [c for c in range(10)]

        >>> c

        [0, 1, 2, 3,4, 5, 6, 7, 8, 9]

        >>>c[1: :2]

        [1, 3, 5, 7,9]

        >>>c[0: :2]

        [0, 2, 4, 6,8]

        由于list的元素可变更,你可以对list的某个元素赋值:

        >>>s2[1] = 3.0

        >>>print s2

        [True, 3.0,'smile']

e、获得表中元素个数

        >>> shaw=['sam',21,67,'A']

        >>>len(shaw)

        4

小结:列表转换成字符串  

    Python join() 方法用于将序列中的元素以指定的字符连接生成一个新的字符串

    join()方法语法:

        str.join(sequence)

    实例:

#!/usr/bin/python
str ="-";
seq =("a", "b", "c"); # 字符串序列
printstr.join( seq );
结果:
a-b-c

二.python字典

    词典和列表类似的地方,是包含有多个元素,每个元素以逗号分隔。但词典的元素包含有两部分,键和值,常见的是以字符串来表示键,也可以使用数字或者真值来表示键(不可变的对象可以作为键)。值可以是任意对象。键和值两者一一对应

  创建字典:

      >>> shaw = {'shaw':23, 'sam':28,'alices':22}

>>> print type(shaw)

<type 'dict'>

>>> print shaw['sam']

28

>>> shaw['alices']= 18

>>> print shaw

{'shaw': 23, 'sam': 28, 'alices': 18}

与列表不同的是,词典的元素没有顺序。你不能通过下标引用元素。词典是通过键来引用

   字典添加新元素:

      >>> dong = {'shaw':23,'sam':33}

>>> print dong

{'shaw': 23, 'sam': 33}

>>> dong['alex'] = 35

>>> print dong

{'alex': 35, 'shaw': 23, 'sam': 33}

  字典常用方法:

      >>>print dic.keys()           # 返回dic所有的键

        >>>print dic.values()         # 返回dic所有的值

        >>>print dic.items()          # 返回dic所有的元素(键值对)

        >>>dic.clear()                # 清空dic,dict变为{}

        >>>del dic['tom']             # 删除 dic 的‘tom’元素

        >>>dic.popitem()                # 默认删除第一个

        >>>dic.copy()               # 拷贝字典

        >>>dic.pop(key)             # 删除某个键值对

        >>> shopinfo.has_key('Apple')   # 查询字典中是否有某键(返回Flase/True)

        >>>dict.update(dict2)          # 把字典dict2的键/值对更新到dict里

        >>>shopinfo.get('shaw')     # 返回指定键的值,若没有该键返回默认值(none)

        >>>shipinfo.setdefault(‘a’:123)        #如果dict中已有a,则不会被覆盖

额外内容: 

1、del是Python中保留的关键字,用于删除对象

Python删除列表,变量

    Del [6:10]

    Del a

    Del 可以删除所有类型变量内容和变量

   2、与列表类似,你可以用len()查询词典中的元素总数

        >>>print(len(dic))

   3、str转成list

        >>> shaw = 'shaw 123'

>>> print shaw,type(shaw)

shaw 123 <type 'str'>

>>> shaw.split()

['shaw', '123']

   4、list转成str

     ''.join()     ‘’之间字符,指定以什么字符把列表拼接成字符串 

        >>> ling = ['shaw','sam']

        >>> print ling,type(ling)

        ['shaw', 'sam'] <type 'list'>

        >>> '-'.join(ling)

        'shaw-sam'  

   5、python枚举函数:(enumerate)

    enumerate在循环时,可以同时访问到当前str的索引

>>> for key, value in enumerate('sdafsd'):prinTKEy,value

...

0 s

1 d

2 a

3 f

4 s

5 d

   6、Python isdigit()

    检测(判断)字符串是否只由数字组成

#!/bin/env python
# -*- coding:utf-8 -*-
'''
@author: shaw
'''
count = raw_input('please intput you age:').strip()
print type(count)
if count.isdigit():
    count = int(count)
print type(count)
# 执行测试 
please intput you age:999
<type 'str'>
<type 'int'>

    7、input

       输入什么类型,input就会把输入当做什么类型来处理

    8、python split() 字符串转列表

#!/bin/env python

# -*- coding:utf-8 -*-

'''

@author: shaw

'''

name = 'shaw sam alex'

name = name.split()     什么都不加,默认以空格区分

print name

['shaw', 'sam', 'alex']

三、Python模块

    import modulename

    from module import sayhi 只导入某个模块的某个方法

    import modulename as NewName

 

    Such as:

    import os,sys

    os.system('command') 执行结果的状态值

    os.popen('command')      执行结果

>>> import os,sys

>>> print os.popen('pwd').read()

/root

    commands.getoutput('command')   执行系统命令

>>> import commands

>>> print commands.getoutput('pwd')

/root

    sys.argv() 用来获取命令行参数

四、python 文件处理

    python支持中文:#_*_coding:utf-8_*_

    f = file(文件名,模式)

       模式:

           'r'    #只读

'w'    #写入

'a'    #追加(append)

       比如:

           >>>f= open("test.txt","r")

    文件对象方法

    读取

       content = f.read(N)          # 以“字符串”形式读取N bytes的数据,(立刻把所有文件读到内存)

       content = f.readline()       # 读取一行(不会立刻把所有文件读到内存)

       content = f.readlines()      # 读取所有行(立刻把所有文件读到内存),储存在列表中,(很慢)

       A = f.writelines         #写多行----(把)列表存到文件

       Content = f.xreadlines()    # 一行行读取文件(不会立刻把所有文件读到内存.很快)

    写入

       f.write('I like apple')      # 将'I like apple'写入文件

       file.tell()              #返回当前文件中的位置(读到哪里了)。获得文件指针位置

       file.seek(0)             # 返回到文件开始位置(默认0)

       file.truncate(size=80)      截取文件到80 size个字节,默认为当前文件位置

       f.flush()     # 刷新文件内存缓冲,直接把内存缓冲区的数据立刻写入文件, 而不是被动的等待输出缓冲区写入.

    特殊方法

       f = file(‘shaw.txt’,’r+’) == withopen(‘shaw.txt’,’r+’) as f:

           两者区别:with open会自动关闭文件,不用f.close()

           后者程序执行完,直接回车即可

    修改文件内容:

 import fileinput

for line infileinput.input('shaw.txt',inplace=1, backup='.bak'):  

  line = line.replace('The 4 loops','The shawloops')

  print line,

inplace=1表示:替换文件之后,在写入到源文件

inplace=0或者不写,表示只打印替换后的文件内容,而源文件内容不变

backup='.bak' 表示,在改变源文件内容前,会备份源文件为:x.bak

# 因为是循环所以是全局替换

注意:如果对Python程序没做字符声明,默认情况下,它会以“ASCII”字符编码方式处理程序内容。

Day-练习题:  

  购物车程序


    • 要求用户输入工资,然后打印购物菜单

    • 用户可以不断的购买商品,直到money not enough

    • 退出时,格式化打印用户已购买的商品和剩余money

流程图:

wKiom1alra_TeZpSAABEQQNKCVo485.png

  代码:

#!/bin/env python
#_*_coding:utf-8_*_
'''
@author: shaw
'''
count = 0
shoplist = []
products = ['iphone','bike','notebook','letv','book']
money = [5980,288,4999,998,20]
while count < 3:
    salary =raw_input('please input your salary:').strip()
    #如果工资字符类型输错3次,退出程序
    if count>= 2:
        print'\033[1;31m#Info\033[0m you input error,bye!'
        break
    #判断工资录入数据是否全为数字
    if  salary.isdigit():
        salary= int(salary)
        while True:
           print 'The prodocts of list:'
            fori in products:
               print '    %s'%i,'    \033[1;33m¥%s\033[0m'%money[products.index(i)]
           shoplisting=raw_input('what you want to buy:').strip()
            #判断money是否足够买所选商品
            ifsalary < money[products.index(shoplisting)]:
               print '\033[1;31m### INFO:\033[0m'
               print'    The balance is\033[1;31m%s\033[0m and not enough to shopping,bye !'%salary
               print '    shoplist:'
               for i in shoplist:
                   print '      %s'%i,'    ¥%s'%money[products.index(i)]
               count = 100
               break
           salary = salary - money[products.index(shoplisting)]
           print 'The current balance is \033[0;32m%s\033[0m'%salary
           shoplist.append(shoplisting)
    else:
        print'\033[1;32m#Info\033[0m Please enter a number.'
        count+=1
    if count ==100:
           break


相关文章