在python的类中动态添加属性与生成对象
本文将通过一下几个方面来一一进行解决 nbsp;nbsp;nbsp;nbsp;nbsp; 1、程序的主要功能 nbsp;nbsp;nbsp;nbsp;nbsp; 2、实现过程 nbsp;nbsp;nbsp;nbsp;nbsp; 3、类的定义 nbsp;nbsp;nbsp;nbsp;nbsp; 4、用生成器generator动态更新每个对象并返回对象 nbsp;nbsp;nbsp;nbsp;nbsp; 5、使用strip 去除不必要的字符 nbsp;nbsp;nbsp;nbsp;nbsp; 6、rematch匹配字符串 nbsp;nbsp;nbsp;nbsp;nbsp; 7、使用timestrptime提取字符串转化为时间对象 nbsp;nbsp;nbsp;nbsp;nbsp; 8、完整代码 程序的主要功能 现在有个存储用户信息的像表格一样的文档:第一行是属性,各个属性用逗号(,)分隔,从第二行开始每行是各个属性对应的值,每行代表一个用户。如何实现读入这个文档,每行输出一个用户对象呢? 每个文档都很大,如果一次性把所有行生成的那么多对象存成列表返回,内存会崩溃。程序中每次只能存一个行生成的对象。 用逗号隔开的每个字符串,前后可能有双引号(”)或者单引号('),例如”张三“,要把引号去掉;如果是数字,有+000000001.24这样的,要把前面的+和0都去掉,提取出1.24 文档中有时间,形式可能是2013-10-29,也可能是2013/10/29 2:23:56 这样的形式,要把这样的字符串转成时间类型 这样的文档有好多个,每个的属性都不一样,例如这个是用户的信息,那个是通话纪录。所以类中的具体属性有哪些要根据文档的第一行动态生成 实现过程 1.类的定义 由于属性是动态添加的,属性-值 对也是动态添加的,类中要含有 class UserInfo(object): 'Class to restore UserInformation' def __init__ (self): self.attrilist={} self.__attributes=[] def updateAttributes(self,attributes): self.__attributes=attributes def updatePairs(self,values): for i in range(len(values)): self.attrilist[self.__attributes[i]]=values[i] 2.用生成器(generator)动态更新每个对象并返回对象 生成器相当于一个只需要初始化一次,就可自动运行多次的函数,每次循环返回一个结果。不过函数用 def fib(max): n, a, b = 0, 0, 1 while n lt; max: print(b) a, b = b, a + b n = n + 1 return 'done' 我们计算数列的前6个数: gt;gt;gt; fib(6) 1 1 2 3 5 8 'done' 如果用生成器的话,只要把 def fib(max): n, a, b = 0, 0, 1 while n lt; max: yield b a, b = b, a + b n = n + 1 使用方法: gt;gt;gt; f = fib(6) gt;gt;gt; f lt;generator object fib at 0x104feaaa0gt; gt;gt;gt; for i in f: ... print(i) ... 1 1 2 3 5 8 gt;gt;gt; 可以看到,生成器fib本身是个对象,每次执行到yield会中断返回一个结果,下次又继续从 在我的程序中,生成器部分代码如下: def ObjectGenerator(maxlinenum): filename='/home/thinkit/Documents/usr_info/USER.csv' attributes=[] linenum=1 a=UserInfo() file=open(filename) while linenum lt; maxlinenum: values=[] line=str.decode(file.readline(),'gb2312')#linecache.getline(filename, linenum,'gb2312') if line=='': print'reading fail! Please check filename!' break str_list=line.split(',') for item in str_list: item=item.strip() item=item.strip('"') item=item.strip(''') item=item.strip('+0*') item=catchTime(item) if linenum==1: attributes.append(item) else: values.append(item) if linenum==1: a.updateAttributes(attributes) else: a.updatePairs(values) yield a.attrilist #change to ' a ' to use linenum = linenum +1 其中, 3.使用strip 去除不必要的字符 从上面代码中,可以看到使用 item=item.strip()#除去字符串前后的所有转义字符,如t,n等 item=item.strip('"')#除去前后的" item=item.strip(''') item=item.strip('+0*')#除去前后的+00...00,*表示0的个数可以任意多,也可以没有 4.re.match匹配字符串 函数语法: re.match(pattern, string, flags=0) 函数参数说明: 参数nbsp;nbsp;nbsp;nbsp;nbsp;nbsp;nbsp;nbsp;nbsp;nbsp; 描述 patternnbsp;nbsp;nbsp; nbsp;nbsp; 匹配的正则表达式 stringnbsp;nbsp;nbsp;nbsp;nbsp;nbsp;nbsp; nbsp;要匹配的字符串。 flagsnbsp;nbsp;nbsp;nbsp;nbsp;nbsp;nbsp;nbsp;nbsp; 标志位,用于控制正则表达式的匹配方式,如:是否区分大小写,多行匹配等等。 若匹配成功re.match方法返回一个匹配的对象,否则返回None。` (编辑:淮北站长网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |