shadowturtle

  博客园 :: 首页 :: 博问 :: 闪存 :: 新随笔 :: 联系 :: 订阅 订阅 :: 管理 ::

写惯了C ,老是会把C的语法写入python,问题百出

关于 Python 列表(list)、字典(dict)、字符串(string)常用基本操作有个博客写得比较详细:

http://blog.csdn.net/business122/article/details/7536991

创建列表

sample_list = ['a',1,('a','b')]

 

Python 列表操作

sample_list = ['a','b',0,1,3]

 

得到列表中的某一个值

value_start = sample_list[0]

end_value = sample_list[-1]

 

删除列表的第一个值

del sample_list[0]

 

在列表中插入一个值

sample_list[0:0] = ['sample value']

 

得到列表的长度

list_length = len(sample_list)

 

列表遍历

for element in sample_list:

    print 'element' 

    

Python 列表高级操作/技巧

 

产生一个数值递增列表

num_inc_list = range(30)

#will return a list [0,1,2,...,29]

 

用某个固定值初始化列表

initial_value = 0

list_length = 5

sample_list = [ initial_value for i in range(10)]

sample_list = [initial_value]*list_length

# sample_list ==[0,0,0,0,0]

 

 

附:python内置类型

1、list:列表(即动态数组,C++标准库的vector,但可含不同类型的元素于一个list中)

a = ["I","you","he","she"]      #元素可为任何类型。

 

下标:按下标读写,就当作数组处理

以0开始,有负下标的使用

0第一个元素,-1最后一个元素,

-len第一个元素,len-1最后一个元素

取list的元素数量                

len(list)   #list的长度。实际该方法是调用了此对象的__len__(self)方法。 

 

创建连续的list

L = range(1,5)      #即 L=[1,2,3,4],不含最后一个元素

L = range(1, 10, 2) #即 L=[1, 3, 5, 7, 9]

 

list的方法

L.append(var)   #追加元素

L.insert(index,var)

L.pop(var)      #返回最后一个元素,并从list中删除之

L.remove(var)   #删除第一次出现的该元素

L.count(var)    #该元素在列表中出现的个数

L.index(var)    #该元素的位置,无则抛异常 

L.extend(list)  #追加list,即合并list到L上

L.sort()        #排序

L.reverse()     #倒序

list 操作符:,+,*,关键字del

a[1:]       #片段操作符,用于子list的提取

[1,2]+[3,4] #为[1,2,3,4]。同extend()

[2]*4       #为[2,2,2,2]

del L[1]    #删除指定下标的元素

del L[1:3]  #删除指定下标范围的元素

list的复制

L1 = L      #L1为L的别名,用C来说就是指针地址相同,对L1操作即对L操作。函数参数就是这样传递的

L1 = L[:]   #L1为L的克隆,即另一个拷贝。

        

list comprehension

   [ <expr1> for k in L if <expr2> ]

                

2、dictionary: 字典(即C++标准库的map)

dict = {'ob1':'computer', 'ob2':'mouse', 'ob3':'printer'}

每一个元素是pair,包含key、value两部分。key是Integer或string类型,value 是任意类型。

键是唯一的,字典只认最后一个赋的键值。

 

dictionary的方法

D.get(key, 0)       #同dict[key],多了个没有则返回缺省值,0。[]没有则抛异常

D.has_key(key)      #有该键返回TRUE,否则FALSE

D.keys()            #返回字典键的列表

D.values()          #以列表的形式返回字典中的值,返回值的列表中可包含重复元素

D.items()           #将所有的字典项以列表方式返回,这些列表中的每一项都来自于(键,值),但是项在返回时并没有特殊的顺序         

 

D.update(dict2)     #增加合并字典

D.popitem()         #得到一个pair,并从字典中删除它。已空则抛异常

D.clear()           #清空字典,同del dict

D.copy()            #拷贝字典

D.cmp(dict1,dict2)  #比较字典,(优先级为元素个数、键大小、键值大小)

                    #第一个大返回1,小返回-1,一样返回0

            

dictionary的复制

dict1 = dict        #别名

dict2=dict.copy()   #克隆,即另一个拷贝。

 

3、tuple:元组(即常量数组)

tuple = ('a', 'b', 'c', 'd', 'e')

可以用list的 [],:操作符提取元素。就是不能直接修改元素。

 

4、string:     字符串(即不能修改的字符list)

str = "Hello My friend"

字符串是一个整体。如果你想直接修改字符串的某一部分,是不可能的。但我们能够读出字符串的某一部分。

子字符串的提取

str[:6]

字符串包含判断操作符:in,not in

"He" in str

"she" not in str

 

string模块,还提供了很多方法,如

S.find(substring, [start [,end]]) #可指范围查找子串,返回索引值,否则返回-1

S.rfind(substring,[start [,end]]) #反向查找

S.index(substring,[start [,end]]) #同find,只是找不到产生ValueError异常

S.rindex(substring,[start [,end]])#同上反向查找

S.count(substring,[start [,end]]) #返回找到子串的个数

 

S.lowercase()

S.capitalize()      #首字母大写

S.lower()           #转小写

S.upper()           #转大写

S.swapcase()        #大小写互换

 

S.split(str, ' ')   #将string转list,以空格切分

S.join(list, ' ')   #将list转string,以空格连接

 

处理字符串的内置函数

len(str)                #串长度

cmp("my friend", str)   #字符串比较。第一个大,返回1

max('abcxyz')           #寻找字符串中最大的字符

min('abcxyz')           #寻找字符串中最小的字符

 

string的转换

            

float(str) #变成浮点数,float("1e-1")  结果为0.1

int(str)        #变成整型,  int("12")  结果为12

int(str,base)   #变成base进制整型数,int("11",2) 结果为2

long(str)       #变成长整型,

long(str,base)  #变成base进制长整型,

 

字符串的格式化(注意其转义字符,大多如C语言的,略)

str_format % (参数列表) #参数列表是以tuple的形式定义的,即不可运行中改变

>>>print ""%s's height is %dcm" % ("My brother", 180)

          #结果显示为 My brother's height is 180cm

 

。。。。。。。。。。。。。。。。。。

 

list 和 tuple 的相互转化

 

tuple(ls) 

list(ls)

 

字典

dict1={‘name’:‘earth’,'port':80}

for key in dict1:

  print 'key=%s,value=%s' % (key,dict1[key])

key=name,value=earth

key=prot,value=80

列表:

aList[a,a,a,12]

1. 全局变量

python 在h文件中定义变量为全局,并没有用。

在函数中使用该变量需要再定义一次为全局

global managefileDIR,clientPath,manageIP,clientIP

clientPath = self.config.get("General","CLIENTPATH")

class INIFILE:

    def __init__(self,striniFile="mc.ini"):
        self.config = ConfigParser.ConfigParser()
        if striniFile == "" :
            print "read ini error"
            sys.exit()
        striniFile = self.config.read(striniFile)
        if striniFile == "":
            print "read ini error"
            print self.i

    def initdata(self):
        global clientIP,managefileDIR,clientPath,manageIP
        clientPath = self.config.get("General","CLIENTPATH")


class Servicecommand:

    def FileTransfer(self,strclientIP=clientIP, strclientPath=clientPath,strmanagefileDIR=managefileDIR,strmanageIP=manageIP):
        global clientIP,managefileDIR,clientPath,manageIP
        if strclientIP != "" and strclientIP != clientIP:
            clientIP = strclientIP

 

如果去掉了 FileTransfer这行红字,将会提示 UnboundLocalError: local variable 'clientPath' referenced before assignment

而去掉了initdata中的global,并不会将return 这些变量的数据

 

2. import 文件夹下

python要import 当前目录中一个文件夹下的东西,必须要先设置sys.path,不像VC一样能直接include

test.py

include/h.py

test.py想要用h.py

必须在test.py中加入以下几行

sys.path.append("include")
from h import *

导入模块:
import:模块名
import:模块名as 新名字
from:模块名 import 函数名

 

python当前找不到模块的话,会从sys模块中的path变量指定的目录查找

3. Python string

http://kb.cnblogs.com/a/1285346/

4. NameError: name "****" is not defined

Python 定义了全局变量,必须先初始化。

h.py :

global availableClientIP

Test.py :

print len(availableClientIP)
就会报错 NameError: name “availableClientIP” is not defined

h.py 下需要定义成

global availableClientIP

availableClientIP=“”

pyhon脚本语言还是非常非常的原始,对写惯C,或者初学者真是非常头疼的事情

posted on 2012-11-28 10:43  shadowturtle  阅读(302)  评论(0编辑  收藏  举报