⑴ python list操作
你不应该用raw_input(),要用input()。
raw_input会把你输入的内容变成字符串,而input不会
>>> a=input(' ')
[['0'],['0']]
>>> a
[['0'], ['0']]
>>> len(a)
2
⑵ python list操作
用 dict comprehension 才是王道啊…搏慎埋基蚂…
#....
#totallistispreparedhere
#....
result孝如={totallist[i]:totallist[i+1]foriinrange(0,len(totallist),2)}
⑶ Python中内置数据类型list,tuple,dict,set的区别和用法
这篇文章主要给大家介绍了Python中内置数据类型list,tuple,dict,set的区别和用法,都是非常基础的知识,十分的细致全面,有需要的小伙伴可以参考下。
Python语言简洁明了,可以用较少的代码实现同样的功能。这其中Python的四个内置数据类型功不可没,他们即是list, tuple, dict, set。这里对他们进行一个简明的总结。
List
字面意思就是一个集合,在Python中List中的元素用中括号[]来表示,可以这样定义一个List:
L = [12, 'China', 19.998]
可以看到并不要求元素的类型都是一样的。当然也可以定义一个空的List:
L = []
Python中的List是有序的,所以要访问List的话显然要通过序号来访问,就像是数组的下标一样,一样是下标从0开始:
>>> print L[0]
12
千万不要越界,否则会报错
>>> print L[3]
Traceback (most recent call last):
File "<stdin>", line 1, in <mole>
IndexError: list index out of range
List也可以倒序访问,通过“倒数第x个”这样的下标来表示序号,比如-1这个下标就表示倒数第一个元素:
>>> L = [12, 'China', 19.998]
>>> print L[-1]
19.998
-4的话显然就越界了
>>> print L[-4]
Traceback (most recent call last):
File "<pyshell#2>", line 1, in <mole>
print L[-4]
IndexError: list index out of range
>>>
List通过内置的append()方法来添加到尾部,通过insert()方法添加到指定位置(下标从0开始):
>>> L = [12, 'China', 19.998]
>>> L.append('Jack')
>>> print L
[12, 'China', 19.998, 'Jack']
>>> L.insert(1, 3.14)
>>> print L
[12, 3.14, 'China', 19.998, 'Jack']
>>>
通过pop()删除最后尾部元素,也可以指定一参数删除指定位置:
>>> L.pop()
'Jack'
>>> print L
[12, 3.14, 'China', 19.998]
>>> L.pop(0)
12
>>> print L
[3.14, 'China', 19.998]
也可以通过下标进行复制替换
>>> L[1] = 'America'
>>> print L
[3.14, 'America', 19.998]
Tuple
Tuple可以看做是一种“不变”的List,访问也是通过下标,用小括号()表示:
>>> t = (3.14, 'China', 'Jason')
>>> print t
(3.14, 'China', 'Jason')
但是不能重新赋值替换:
>>> t[1] = 'America'
Traceback (most recent call last):
File "<pyshell#21>", line 1, in <mole>
t[1] = 'America'
TypeError: 'tuple' object does not support item assignment
也没有pop和insert、append方法。
可以创建空元素的tuple:
t = ()
或者单元素tuple (比如加一个逗号防止和声明一个整形歧义):
t = (3.14,)
那么tuple这个类型到底有什么用处呢?要知道如果你希望一个函数返回多个返回值,其实只要返回一个tuple就可以了,因为tuple里面的含有多个值,而且是不可变的(就像是java里面的final)。当然,tuple也是可变的,比如:
>>> t = (3.14, 'China', 'Jason', ['A', 'B'])
>>> print t
(3.14, 'China', 'Jason', ['A', 'B'])
>>> L = t[3]
>>> L[0] = 122
>>> L[1] = 233
>>> print t
(3.14, 'China', 'Jason', [122, 233])
这是因为Tuple所谓的不可变指的是指向的位置不可变,因为本例子中第四个元素并不是基本类型,而是一个List类型,所以t指向的该List的位置是不变的,但是List本身的内容是可以变化的,因为List本身在内存中的分配并不是连续的。
Dict
Dict是Python中非常重要的数据类型,就像它的字面意思一样,它是个活字典,其实就是Key-Value键值对,类似于HashMap,可以用花括号{}通过类似于定义一个C语言的结构体那样去定义它:
>>> d = {
'Adam': 95,
'Lisa': 85,
'Bart': 59,
'Paul': 75
}
>>> print d
{'Lisa': 85, 'Paul': 75, 'Adam': 95, 'Bart': 59}
可以看到打印出来的结果都是Key:Value的格式,可以通过len函数计算它的长度(List,tuple也可以):
>>> len(d)
4
可以直接通过键值对方式添加dict中的元素:
>>> print d
{'Lisa': 85, 'Paul': 75, 'Adam': 95, 'Bart': 59}
>>> d['Jone'] = 99
>>> print d
{'Lisa': 85, 'Paul': 75, 'Adam': 95, 'Jone': 99, 'Bart': 59}
List和Tuple用下标来访问内容,而Dict用Key来访问: (字符串、整型、浮点型和元组tuple都可以作为dict的key)
>>> print d['Adam']
95
如果Key不存在,会报错:
>>> print d['Jack']
Traceback (most recent call last):
File "<pyshell#40>", line 1, in <mole>
print d['Jack']
KeyError: 'Jack'
所以访问之前最好先查询下key是否存在:
>>> if 'Adam' in d : print 'exist key'
exist key
或者直接用保险的get方法:
>>> print d.get('Adam')
95
>>> print d.get('Jason')
None
至于遍历一个dict,实际上是在遍历它的所有的Key的集合,然后用这个Key来获得对应的Value:
>>> for key in d : print key, ':', d.get(key)
Lisa : 85
Paul : 75
Adam : 95
Bart : 59
Dict具有一些特点:
查找速度快。无论是10个还是10万个,速度都是一样的,但是代价是耗费的内存大。List相反,占用内存小,但是查找速度慢。这就好比是数组和链表的区别,数组并不知道要开辟多少空间,所以往往开始就会开辟一个大空间,但是直接通过下标查找速度快;而链表占用的空间小,但是查找的时候必须顺序的遍历导致速度很慢
没有顺序。Dict是无顺序的,而List是有序的集合,所以不能用Dict来存储有序集合
Key不可变,Value可变。一旦一个键值对加入dict后,它对应的key就不能再变了,但是Value是可以变化的。所以List不可以当做Dict的Key,但是可以作为Value:
>>> print d
{'Lisa': 85, 'Paul': 75, 'Adam': 95, 'Jone': 99, 'Bart': 59}
>>> d['NewList'] = [12, 23, 'Jack']
>>> print d
{'Bart': 59, 'NewList': [12, 23, 'Jack'], 'Adam': 95, 'Jone': 99, 'Lisa': 85, 'Paul': 75}
Key不可重复。(下面例子中添加了一个'Jone':0,但是实际上原来已经有'Jone'这个Key了,所以仅仅是改了原来的value)
>>> print d
{'Bart': 59, 'NewList': [12, 23, 'Jack'], 'Adam': 95, 'Jone': 99, 'Lisa': 85, 'Paul': 75}
>>> d['Jone'] = 0
>>> print d
{'Bart': 59, 'NewList': [12, 23, 'Jack'], 'Adam': 95, 'Jone': 0, 'Lisa': 85, 'Paul': 75}
Dict的合并,如何将两个Dict合并为一个,可以用dict函数:
>>> d1 = {'mike':12, 'jack':19}
>>> d2 = {'jone':22, 'ivy':17}
>>> dMerge = dict(d1.items() + d2.items())
>>> print dMerge
{'mike': 12, 'jack': 19, 'jone': 22, 'ivy': 17}
或者
>>> dMerge2 = dict(d1, **d2)
>>> print dMerge2
{'mike': 12, 'jack': 19, 'jone': 22, 'ivy': 17}
方法2比方法1速度快很多,方法2等同于:
>>> dMerge3 = dict(d1)
>>> dMerge3.update(d2)
>>> print dMerge
{'mike': 12, 'jack': 19, 'jone': 22, 'ivy': 17}
set
set就像是把Dict中的key抽出来了一样,类似于一个List,但是内容又不能重复,通过调用set()方法创建:
>>> s = set(['A', 'B', 'C'])
就像dict是无序的一样,set也是无序的,也不能包含重复的元素。
对于访问一个set的意义就仅仅在于查看某个元素是否在这个集合里面:
>>> print 'A' in s
True
>>> print 'D' in s
False
大小写是敏感的。
也通过for来遍历:
s = set([('Adam', 95), ('Lisa', 85), ('Bart', 59)])
#tuple
for x in s:
print x[0],':',x[1]
>>>
Lisa : 85
Adam : 95
Bart : 59
通过add和remove来添加、删除元素(保持不重复),添加元素时,用set的add()方法:
>>> s = set([1, 2, 3])
>>> s.add(4)
>>> print s
set([1, 2, 3, 4])
如果添加的元素已经存在于set中,add()不会报错,但是不会加进去了:
>>> s = set([1, 2, 3])
>>> s.add(3)
>>> print s
set([1, 2, 3])
删除set中的元素时,用set的remove()方法:
>>> s = set([1, 2, 3, 4])
>>> s.remove(4)
>>> print s
set([1, 2, 3])
如果删除的元素不存在set中,remove()会报错:
>>> s = set([1, 2, 3])
>>> s.remove(4)
Traceback (most recent call last):
File "<stdin>", line 1, in <mole>
KeyError: 4
所以如果我们要判断一个元素是否在一些不同的条件内符合,用set是最好的选择,下面例子:
months = set(['Jan','Feb','Mar','Apr','May','Jun','Jul','Aug','Sep','Oct','Nov','Dec',])
x1 = 'Feb'
x2 = 'Sun'
if x1 in months:
print 'x1: ok'
else:
print 'x1: error'
if x2 in months:
print 'x2: ok'
else:
print 'x2: error'
>>>
x1: ok
x2: error
⑷ python中list
这个原因是python默认参数在定义时求值(比如说当你首次导入模块时),在这里就是你定义这个函数的时候求的值,所以你后面的f(3)会沿袭之前的默认参数的值
⑸ python中关于list的问题
如果要把ok1作为一个列表嵌套到lips中,你就要把ok1放在lips上面
⑹ python怎么用list
commonest=[1,2,2,2,1,3,4,5,1,1]print(commonest.count(1))需要把数据存储到列表中,列表的count的方法可以统计某个元素出现的次数
⑺ python怎么生成list的所有元素的组合
生成排列可以用proct:
from itertools import proct
l = [1, 2, 3]
print list(proct(l, l))
print list(proct(l, repeat=4))
组合的话可以用combinations:
from itertools import combinations
print list(combinations([1,2,3,4,5], 3))
下面是我以为没有combinations然后自己写的,没有itertools的python(2.6以下)可供参考。
import
def combine(l, n):
answers = []
one = [0] * n
def next_c(li = 0, ni = 0):
if ni == n:
answers.append(.(one))
return
for lj in xrange(li, len(l)):
one[ni] = l[lj]
next_c(lj + 1, ni + 1)
next_c()
return answers
print combine([1, 2, 3, 4, 5], 3)
输出:
[[1, 2, 3], [1, 2, 4], [1, 2, 5], [1, 3, 4], [1, 3, 5], [1, 4, 5], [2, 3, 4], [2, 3, 5], [2, 4, 5], [3, 4, 5]]
⑻ python怎么创建一个list
a=[]或a=list(携颤)建立空的list,添加元蠢隐梁素b使用方法append或带运extend
a.append(b);a.extend(b)
a=[1,2,3]建立包含元素的list,字符串要加引号,元素间逗号隔开
以上在python3.4中
⑼ python中的list
list是一个函数,将参数强制转换成列表
list((1,4,7)) 对元组(1,4,7)使用list函数就返回列表[1,4,7]
map(list,zip(*a))表示对zip(*a)的每一个单位都执行list函数
而且这在python 2.6.6中执行正常,执行效果如下
>>> a=[[1,2,3],[4,5,6],[7,8,9]]
>>> zip(*a)
[(1, 4, 7), (2, 5, 8), (3, 6, 9)]
>>> map(list,zip(*a))
[[1, 4, 7], [2, 5, 8], [3, 6, 9]]
⑽ python的list和c的数组有什么区别
始看Python现半月前看Python核编程Dive into
Python两本书说半月看两本都知道囫囵吞枣我暂没需求拿做型发主要平程序test用用所
我策略整体浏览用候现查说核编程第版太古讲2.2前东西我看翻译电版翻译晦涩看完
点云雾看网家说DIP啄木鸟免费电文档找看说呢讲比核编程适合第看初者我所觉讲
看核编程些概念些模糊看本书明白少要初者看本保证理解
面习程翻阅资料程总结些Cpython比较明显同处向细节肯定没总结完比态
函数lambda些我都懒往写实际作两种完全同语言面些差异冰山角已权抛砖引玉吧至少应该我相同研究
兴趣考虑否习另门语言朋友点帮助文算DIP习笔记吧顺带说句要朋友解帮忙推荐实战性强Python
教材语言东西练手光比划能
习目
我研究向嵌入式显C语言我主要语言我语言者我前觉于做研究应用说解门语言
精通门语言所看python主要python更利于快速发些程序现认识研究应用能离要
想计算机工程竞争立足必须懂C语言真要做高性能编程,
能机器体系架构抛脑让Python虚拟机(或Java虚拟机等)帮搞定所底层越越CPU
core越越恐怖内存性能瓶颈于层发员说所谓高性能程序发员说些透明应用自掌控比较
效些场合汇编C替代光知道C够掌握门面向象语言相更高层语言仅发展利自技
术认识产帮助
要问我说谁更重要我觉C更重要C习曲线更陡貌似简单实际处都陷阱看比较简单低效程序12月
能搞定谈优化深层难度嘛需要功底按算旦C语言基础打计算机理解其语言理解都裨益比
C基础说1python能写些短程序面优化算都非基本语句换换
说 Python实际层应用Python比C便层
觉既懂C进步掌握C++应该水渠C++C超集我喜欢C++繁琐巨所才决定看看Python我喜欢Python优雅与快捷
语言类型
CPython种态类型语言强类型语言类理解呢概按照列说明类:
静态类型语言
种编译期间确定数据类型语言数静态类型语言通要求使用任变量前声明其数据类型保证点Java C 静态类型语言
态类型语言
种运行期间才确定数据类型语言与静态类型相反Python 态类型确定变量类型您第给赋值候
强类型语言
种总强制类型定义语言Java Python 强制类型定义您整数明确进行转换 能字符串
弱类型语言
种类型忽略语言与强类型相反VBScript 弱类型 VBScript 您字符串 ‘12′ 整数 3 进行连接字符串’123′看整数 123 所些都需要任何显示转换
象机制
具体理解态确定变量类型要PythonObject象机制说起Objects(称象)Python于数据
抽象Python所数据都由象或者象间关系表示函数象字符串象每东西都象概念每象都三种属性:
实体类型值理解实体理解象重要步实体旦创建直改变显式摧毁同通意义讲决定象所支持操作
式类型(type包括numberstringtuple及其)改变改变能值要找具体点说明实体相于
象内存址本质存类型值都实体外呈现Python提供些接口让使用者象交互比id()函数用获象实体
整形表示(实际址)type()函数获取其类型
object机制c所具备主要体现面几点:
1 刚才说c静态类型语言我定义int a, char
b等等必须源代码面事先规定比我Python面任意处直接规定a =
lka类型string其赋值候才决定我须代码明确写C面我必须显式规定char *a =
lk工事先规定a类型
2 由于C没象概念数据表示比说两int变量ab我想比较用a ==
b判断两字符串变量ab我用strcmp比较ab本质指向字符串指针直接用==比较
比较实际指针存储值——址
Java呢我通使用 str1 == str2 确定两字符串变量否指向同块物理内存位置叫做象同性 Java 要比较两字符串值要使用 str1.equals(str2)
Python前两者都由于象引入我用is运算符比较两象实体具体象type没关系
比象tuplestring甚至class都用is比较本质象同性比较Java
==类似 Cpointer比较类似Python==比较值比较
3
由于象机制引入让Python使用非灵比我用自省查看内存象形式存其模块函数获取信息并进行
操作用种定义没名称函数按函数声明参数顺序调用函数甚至引用事先并知道名称函数 些操作C都想象
4 意思细节类型象行影响各面比说a = 1; b =
1语句Python面引发能ab同指向值1象能别指向两值1象例语句c = []; d
= []cd肯定指向同新创建空list没完c = d =
[]语句呢cd指向相同list象些区别都c没
我说说python慢主要原function call
overhead比较所东西现都象contruct destroy 花费连1 + 1 都 function
call像’12′+’45′ 要 create a third string object, then calls the string
obj’s __add想知速度何能快起
列表数组
析PythonlistC数组总趣相信能些朋友初列表候都作数组初于list数组区别定性主要集两点首先list包含同数据类型比
["this", 1, "is", "an", "array"]
List放C其实字符串数组相于二维
其呢list其本身象C单纯数组同于List操作重载运算符带些问题比面例:
加入我要产维列表用面语句
A = [[None] * 2] * 3
结A值
[[None, None], [None, None], [None, None]]
初看没问题典型二维数组形式列表现我想修改第None值用语句
A[0][0] = 5
现我再看看A值:
[[5, None], [5, None], [5, None]]
发现问题没用 * 复制创建象引用真创建 *3 创建包含三引用列表三引用都指向同度2列表其行改变显示所行想要解决我创建
A = [None]*3
for i in range(3):
A[i] = [None] * 2
创建包含三同度2列表
所直强调越复杂东西越灵越容易错
代码优化
C简单语言我考虑优化候通想简单比系统级调用越少越(缓冲区机制)消除循环低效率必要系统引用等
等其实主要都基于系统硬件细节考虑Python完全面说些优化形式于Python仍实用由于
Python语形式千差万别库模块种所于语言本身言值注意优化要点举几例吧
比我list L1想要构建新list L2L2包括L14元素按照直接想代码应该
L2 = []
for i in range[3]:
L2.append(L1[i])
更加优化优美版本
L2 = L1[:3]
再比s1..s7字符串(10K+)join([s1,s2,s3,s4,s5,s6,s7])比
s1+s2+s3+s4+s5+s6+s7快,者计算表达式join()则程完所复制于字符串操作
字符串象使用replace()仅没固定字符串模式才使用则表达式
所说优化评判标准说C短精悍Python博精深
includeimport
C语言include非简单形式单意义明确需要用外部函数等资源用includePython相似
机制import乍看两家伙挺像都我要用外部资源(见函数或者模块(Python))用指明其实
两者处理机制本质区别于Cinclude用于告诉预处理器include指定文件内容都给我作本源文件现
import呢简单面内容*直接*插入本面玩意更加灵事实几乎所类似机制Python都比C灵说C
C简练我其实更喜欢C
简单说说灵性importpython三种形式import X, from X import *( or a,b,c……),
X = __import__(’x')用第二种比较便像第种用X.mole调用模块from X
import *import些publicmole(般都__命名模块)指定a,b,cimport
候用哪种形式呢应该说数模块文档都明确告诉应该用哪种形式需要用象from X import
*能更合适些目前看数第三Python库都推荐使用from molename import *
种格式做使引入者namespace混乱甚至于些专门设计用于种模式模块(包括Tkinter,
threadingmatplot)都采用种式仅仅需要某象类a用from X import a比用import
X.a更调用a函数直接用a.function()既用加X
连自希望import模块都知道办请注意Python优势体现我用
__import__(mole)调用mole其mole字符串运行再决定底要调用mole举
例:
def classFromMole (mole, Name):
mod = __import__ (mole)
return getattr (mod, Name)
定义函数classFromMole代码任何候调用
o = classFromMole (MoleOfTheClass, NameOfTheAttribute)()
需要传入字符串形式希望import模块MoleOfTheClass其属性名字NameOfTheAttribute(数据)能调用名字字符串用事先指定根据运行情况判断
顺带说句Pythonimport顺序默认规定Cinclude点类似我般都先include系统文件再
include自文件(且>区别)Python呢般应该按照顺序import模块:
1. 标准库模块 — sys, os, getopt 等
2. 第三模块
3. 本实现模块
全局变量
谈全局变量呢倒说Pythonc全局变量概念同概念相同使用机制些差异举例:
– mole.py –
globalvar = 1
def func():
print globalvar
# This makes someglobal readonly,
# any attempt to write to someglobal
# would create a new local variable.
def func2():
global globalvar
globalvar = 2
# this allows you to manipulate the global
# variable
func函数globalvar读使用globalvar =
xxx种赋值语句Python重新创造新本象并新值赋给原象值变func2函数由于我事先申明
globalvarglobal更改直接全局变量效