前言

学习使用python已经一年,自从看了python简明教程后就开始使用python编码,并且在两个项目中尝试使用了。在使用的过程中遇到问题就查资料,边学边写,并且把自己学到的东西总结下来,不知不觉已经有三十多页。虽然到目前为止还没有完整的看过一本全面python文档,但我认为这种方式可能更适合用来学习新的语言。
之前发表过一些,这次各个部分均有更新,并且新增了python性能相关总结。

电子版下载:
http://download.csdn.net/detail/chgaowei/4586505

两本不错的书:

《Python参考手册》:对Python各个标准模块,特性介绍的比较详细。

《Python核心编程》:介绍的比较深入,关键是,对Python很多高级特性都有介绍。

一个开源代码:openstack,关于云计算的,用Python写的,可以重点学习一下。

套接字编程:

1、  函数的功能基本和c类似,唯一不同的地方在于当发生错误时,它不是通过返回值来告知的,而是通过触发异常,所以udp中的bind, recvfrom, sendto必须要进行捕捉异常。

2、  套接字在垃圾收集的时候也会关闭。

3、  获取网卡的IP:   

s = socket.socket(socket.AF_INET, socket.SOCK_DGRAM)

return socket.inet_ntoa(fcntl.ioctl(s.fileno(), 0X8915, struct.pack('256s', ethname[:15]))[20:24])

4、  epool使用:

1)  epoll.poll()函数的入参是等待时间,如果缺省,负值,None,则会阻塞住。非阻塞的做法是epoll.poll(0)

2)   

5、   

 

 

字符串的使用:

1、  Python的字符串是不可以改变的。但是你可以操作字符串以形成新的字符串。

2、  字符串中删除一个字串。没有直接提供这个方法,但是replace可以实现:

"abcdef".replace(" ", "")

同样的功能还有一个方法:translate。它的原有作用是将字符串中的某个字符替换为另外一个字符,注意,不是字符串。它的第一个参数是一个转换表。第二个参数是要删除的字符串。我们可以利用第二个参数del,实现这个功能。同时,第一个参数设置为None。

translate可能更高效一点。另外,它的第二个参数可以使一个字符串,含有多个字符,这样就会删除多个。

注意:translate方法不会对这个字符串操作,而是返回一个新的字符串。

txt = txt.translate(None, ' \r\n\t;')

3、  strip方法:去除字符串两侧的空格,返回新的字符串。这个功能非常有用。

4、  str中有一个函数,format,非常强大,有时间一定要看一下。

5、  endswitch:检查字符串是否已某字符串结尾。startswith:检查是否已某字符串开头。

6、 partition:它将字符串按指定的字符串分为三个部分,返回一个元组。第一个是指定字符串前面内容,第二个是指定字符串,第三个是指定字符串后面的内容。用于字符串解析非常好用。

7、 split:将字符串按照某指定字符串分割成多个子字符串,返回一个分割后的列表。

8、 join:将一个字符串列表中的各个字符串连接起来,中间插入指定的字符串。

9、 find的返回值不是false和true,所以不可以直接用于if判断。需要判断if s.find(‘’) >= 0:

10、         基于字典的格式化:

a)    sh = '''

b)    python -mcompileall -fl ../src;

c)    python -mcompileall -fl ../src/micbase;

d)    mkdir%(packname)s;

e)    mdkir%(packname)s;

f)    ''' % {'packname':sys.argv[1], }

g)    print(sh)

11、         字符串的解析:如果出现错误:UnicodeEncodeError:”ascii” codec cannt encode charactersin position 36-39: ordinal not in range(128).

问题的原因是系统默认的编解码库不支持Unicode,所以,需要设置编解码库。

方法:

reload(sys)  #必须要重新加载才可以。

sys.setdefaultencoding(‘gb2312’)

内建函数:

string.capitalize()

 把字符串的第一个字符大写

string.center(width)

 返回一个原字符串居中,并使用空格填充至长度 width 的新串

string.count(str, beg=0, end=len(string))

 返回 str 在 string 里面出现的次数,如果 beg 或者 end 指返回指定范围内 str 出现的次数

string.decode(encoding='UTF-8', errors='strict')

   以 encoding 指定的编码格式解码 string,如果出错默认报ValueError 的异常,除非 errors 指定的是'ignore'或'replace'

string.encode(encoding='UTF-8', errors='strict')

  以 encoding 指定的编码格式编码 string,如果出错默认报ValueError的异常, 除非errors指定的是'ignore'或者'repl

string.endswith(obj, beg=0, end=len(string))

检查字符串是否以 obj 结束,如果 beg 或者 end 指定则检定的范围内是否以 obj 结束, 如果是, 返回True,否则返回Fa

string.expandtabs(tabsize=8)

把字符串 string 中的 tab 符号转为空格, 默认格数 tabsize 是 8.

string.find(str, beg=0, end=len(string))

   检测 str 是否包含在 string 中,如果 beg 和 end 指定范则检查是否包含在指定范围内,如果是返回开始的索引值,返回-1

string.index(str, beg=0, end=len(string))

    跟find()方法一样, 只不过如果str不在string中会报一个异

string.isalnum()

a, b, c  R如果string至少有一个字符并且所有字符都是字母或数字回 True,否则返回 False

string.isalpha()

a, b, c  如果string至少有一个字符并且所有字符都是字母则返回T否则返回 False

string.isdecimal()

b, c, d 如果 string 只包含十进制数字则返回 True 否则返回 False.

string.isdigit()

b, c 如果 string 只包含数字则返回 True 否则返回 False.

string.islower()

b, c 如果 string 中包含至少一个区分大小写的字符,并且所有这些(大小写的)字符都是小写,则返回 True,否则返回 False

string.isnumeric()

b, c, d 如果 string 中只包含数字字符,则返回 True,否则返回 False

string.isspace()

b, c 如果 string 中只包含空格,则返回 True,否则返回 False.

string.istitle()

b, c 如果 string 是标题化的(见 title())则返回 True,否则返回 False

string.isupper()

b, c 如果 string 中包含至少一个区分大小写的字符, 并且所有这些(区分大小写的)字符都是大写,则返回 True,否则返回 False

string.join(seq)

 Merges (concatenates)以 string 作为分隔符,将 seq 中所有的元素(的字符串表示)合并为一个新的字符串

string.ljust(width)

返回一个原字符串左对齐,并使用空格填充至长度 width 的新字符串

string.lower()

 转换 string 中所有大写字符为小写.   

string.lstrip()

  截掉 string 左边的空格

string.partition(str)

e 有点像 find()和 split()的结合体,从 str 出现的第一个位置起,把 字 符 串 string 分 成 一 个 3 元 素 的 元 组 (string_pre_str,str,string_post_str),如果 string 中不包含str 则 string_pre_str == string.

string.replace(str1, str2,  num=string.count(str1))

把 string 中的 str1 替换成 str2,如果 num 指定,        则替换不超过 num 次.

string.rfind(str, beg=0,end=len(string))

类似于 find()函数,不过是从右边开始查找.

string.rindex( str, beg=0,end=len(string))

    类似于 index(), 不过是从右边开始.

string.rjust(width)

返回一个原字符串右对齐,并使用空格填充至长度 width 的新字符串

string.rpartition(str)

e  类似于 partition()函数,不过是从右边开始查找.

string.rstrip()

  删除 string 字符串末尾的空格.

string.split(str="", num=string.count(str))

  以 str 为分隔符切片 string,如果 num有指定值,则仅分隔 num 个子字符串

string.splitlines(num=string.count('\n'))

b, c按照行分隔, 返回一个包含各行作为元素的列表, 如果 num 指定则仅切片 num 个行.

string.startswith(obj, beg=0,end=len(string))

b, e检查字符串是否是以 obj 开头,是则返回 True,否则返回 False。如果beg 和 end 指定值,则在指定范围内检查.

string.strip([obj])

  在 string 上执行 lstrip()和 rstrip()

string.swapcase()

  翻转 string 中的大小写

string.title()

b, c   返回"标题化"的 string,就是说所有单词都是以大写开始,其余字母均为小写(见 istitle())

string.translate(str, del="")

  根据str给出的表(包含256个字符)转换string的字符,要过滤掉的字符放到 del 参数中

string.upper()

 转换 string 中的小写字母为大写

string.zfill(width)

  返回长度为 width 的字符串,原字符串 string 右对齐,前面填充0

 

 

 

 

正则表达式

1、  为什么要学习正则:主要是为了处理字符串更加方便,特别是为后面进行代码生成做储备。

2、  match是匹配字符串的开头是否匹配,而search是查看字符串任意起始位置是否满足。

3、  sub可以对字符串中模式匹配的部分进行替换

4、  split:可以对字符串进行分割,这里是根据模式分割。

re.split('@|:|-','123@sdfsa:sdf-223:342-23-23-21')

将字符串根据模式'@|:|-'分割,

5、   

 

函数的使用:

1、  函数的作用域:函数中定义一个变量,如果和全局变量重名,则全局变量名称就会被覆盖,也就是,这里对这个变量的更改,不会更改全局变量。但是,如果直接使用的话,是会使用全局变量的。同时,如果想要修改全局变量,需要制定是全局变量:global a

2、  xrange用法和range一样,不过更为高效,因为他不会在内存中创建列表。所以,它只能用于循环。

3、  如果函数没有return语句,则他的返回值为None。

4、  关于函数的入参判断:如果如此为空,可能会发生异常。当异常发生后,可能会出现一种情况,一个事情做到了一半,就没有在进行下去,可能会造成内存泄露。这个问题如何解决?按照C的方式,每个入参都做判断是可以解决的,但是这样太麻烦了。而且看很多开源代码页没有这样来做。是不是有更好的方法?换一种思路,在调用之前确保不为空。在看看开源的代码是怎么做的。特别是openstack。

5、  可变入参:*args, **kwargs表示可变入参。

def funtest(a,b, c):

    print(a, b, c)

def fun2(*args,**kwargs):

funtest(*args, **kwargs)

   fun2(1,2,3)

   也可以这样定义:

fun2(a, *args, **kwargs)

如何从可变参数中解析出参数的值?

在fun2中添加打印:可以发现,其实args是一个元组,kwargs是一个字典。

分析:调用fun2(1,2,3),会把a赋值给a,2赋值给元组args,{‘c’=3}赋值给kwargs.

   args和kwargs的顺序不可颠倒。

   args和kwargs可能同时都有值。这样,要获取指定的入参,首先根据看args中有没有,然后根据字符串看kwargs中是否存在。

   如何建一个元组或者字典通过参数传递给一个函数?

   def funtest(a,b, c):

    print(a, b, c)

d = {'a':1, 'b':2,'c':3}

l = (1,2,3)

funtest(*l)

funtest(**d)

*和**在Python中可以实现这个功能。这样会很灵活的。

*和**也可以单独出现。但是,如果同时出现,*必须在**之前。

6、  默认参数或者可选参数,参数顺序:调用时,可以指定默认参数中填充那个。

def funtest(a, b=1, c=2):

    print(a, b, c)

funtest(1, c=5, b=6)

其实,即便定义为:def funtest(a, b, c),也可以通过funtest(1, c=5, b=6)的形式调用。

7、  参数组:*args, **kwargs就是参数组,通过元组和字典将产生携带进来。这个特性有助于更为动态的代码生成。

8、  可变长度参数:

9、  函数的参数中如果有一个是元组,可以这样:

def fun(a, (b,c)):

    print(a, b, c)

fun(1, (1,2))

10、 关于回调,可以使用闭包,生成器,以及对象的__call__属性。都可以封装状态。

11、 函数的可变入参:定义:def dlog(msg, *args):

这样可以定义可变入参,后面根据msg以及args进行格式化。注意一点,args是元组的元组。

dlog(‘%s’, 1,2)

args是((1, 2), )。所以,在格式化的时候,要用:msg% args[0]

 

函数式编程:

1、  lambda使用的误区:

错误的代码:

    for u in userList:

        gcallinfo.userAdd(u)

        curflet.addCompFun(lambda:gcallinfo.userLeave(u))

这里是想为每个用户增加一个处理函数。但是结果是所有的用户都是一个处理函数。原因是lambda它相当于是一个函数定义,而不是函数调用。即便是它出现在for循环中,它仍然是一个函数,而不是多个。

解决的方法是:

   fun = lambda x:lambda :gcallinfo.userLeave(x)

    for u in userList:

        gcallinfo.userAdd(u)

          curflet.addCompFun(fun(u))

使用两个lambda,第一个lambda返回的是一个函数。

当然也可以这样:

    for u in userList:

        gcallinfo.userAdd(u)

          curflet.addCompFun((lambdax:lambda :gcallinfo.userLeave(x))(u))

但是我感觉这样的可读性不好。

 

2、   

 

闭包的使用:

1、  将组成函数的语句和语句的执行环境打包在一起形成的对象,成为闭包。

2、  2.7之前的闭包不支持关键字nonlocal。3.0之后才支持。所以2.7前的闭包不可以使用nonlocal。

3、  这样他就不可以对执行环境中的变量进行更改。

 

字典的使用:

1、  字典的删除:直接使用del dict[k]可能会引发异常;首先判断k是否存在则效率有些低;使用异常使程序结构看起来不好。一个好的方法是pop(k, default v)。这个删除一个k项,并且返回。如果不存在返回默认的v。如果不加默认值,则会引发异常。

2、  直接使用字典下标获取字典的值可能会引发一场。使用get方法则不会,如果不存在会返回none。另外,还可以设置不存在的默认值。

3、  通过字典格式化字符串:print “value is %(key)s” % kvdict

4、  items方法返回一个列表,列表中的元素是一个元组,第一个是key,第二个是value。比较好用的方法。

5、  iteritems:返回的是一个迭代器。如果想要迭代这个字典,iteritems会比items更高效一点。

6、  iterkeys则返回的是key的迭代器。keys返回的是key的list。

7、  values返回值的列表,itervalues返回的是vlaue的迭代器

8、  popitem会随机弹出(同时删除)一个项,则对于想要处理所有的元素,并且删除所有的元素是有帮助的。但是,如果没用元素的话,会抛出异常。

9、  viewitems,viewkeys,viewvalues:这三个函数返回的是一个view对象。这个类似于视图。分别表示(key, value)pair的列表,key的列表,value的列表。一个优点是,如果字典发生变化,view会同步发生变化。在迭代过程中,字典不允许改变,否则会报异常。而且,viewitems的顺序是不定的。

一个替代的方案是:

l = [1,2,3,4,5,6,7]

 

def yfun():

    while True:

        for i in l:

            print(i)

            yield

g = yfun()

列表在迭代的过程中,如果改变,是可以同步的。

10、 字典的键值比较规则:如果是内置类型(int,str,tuple),则是以他们的值作为键值;如果是自定义对象,则是以对象的地址作为键值。——这一点没有完全证实。——最新的发现:对象的比较,内置类型,是因为他们都重写了默认的object的__eq__等方法,所以可以比较内容。自定义对象,没有重写,所以,他们的比较可能会不一样。object默认的比较是什么?目前还不明确,后面再补充吧。可能就是地址(或者对象的唯一标识),而不是对象的内容。涉及到字典,它不是使用的单纯的比较,而是使用的__hash__,它返回的是一个hash值,字典就是根据这个hash只来散布对象的。

 

集合的使用:

1、  集合内部使用hash算法。而有不是kv方式。某种情况下可能会方便。

2、  集合很方便的合并:

c = a | b

取差:c =

3、   

 

列表的使用:

1、  列表的删除:不可以在遍历的过程中删除链表,这样会得到不可预知的后果。可以使用列表的过滤,来获得新的列表。

2、  列表的过滤:

        def filterFun(node):#这个函数做了两个事情哎。

            node.cycleCount = node.cycleCount -1

            return node.cycleCount < 0

       timeoutList = filter(filterFun, timerList)

       对timerList中的每个节点执行函数filterFun,根据filterFun返回的结果,为真的项组成一个新的列表。

3、  list的pop是删除的最后一个元素。pop参数的默认值是-1且pop的对象不可以为空列表。

4、  map: kvlist = map(lambda x:x.strip(), kvlist)。同时,map可以接受多个列表,这个时候,函数也会接受多个参数,分别表示列表的每一个元素:
kvlist = map(lambda x,y:x+y, [1,2,3], [4,5,6])

如果函数为None,则相当于函数zip:

zip([1,2,3],[4,5,6])

[(1,4),(2,5),(3,6)]

5、  生成器表达式:l = [node for node in xrange(5) if node - 3 < 0]:这个的这个方法一定程度上可以替代过滤器和map。

生成器表达式定义:

[expr foriter_var in iterable if cond_expr]

l = [2 for x inxrange(5)]#结果是生成一个含有5个2的列表

一个特殊的用法,条件可以由多个:

[str(i) for i in xrange(8) if i != 5 if i != 4]

6、  print(reduce(lambda x,y: x*y, [2 for x in xrange(38)]))

上面的这个语句是计算2的38次方的值。它用到的是二元函数reduce。它第一次调用是将第一个和第二个元素做入参,后面用他们的结果做x,新的元素做y,最后返回值。

另外,在获取一个38个2的列表也可以使用:[2] * 38。这可能更可读一点。

7、  enumerate:对列表处理,返回的是列表的索引以及节点。

        for index, node in enumerate(timerList):

            if timerId == node.timerId and timerEvent ==node.timerEvent:

                del timerList[index]

8、  列表的分片:[1,2,3,4],l[1:-1]表示从索引从1到倒数第一个,不包含倒数第一个。如果要从某位置到最后,则应该:[1:]

9、 l[i:j:k]:表示切片,从i到j,步长为k。

10、l[i:j]:表示从i到j,不包括索引j。

11、如何在列表的迭代过程中删除元素:

如果在迭代过程中删除,会遍历不完全:

l = [1,2,3,4,5,6]

 

for i in l:

    print(i)

    if i%2 ==0:

        l.remove(i)

这是一个方案,是通过切片操作获取一个新的元素。
for x in a[:]:
    if x < 0: a.remove(x)

 

条件表达式

1、  if 1 :print('------------'):这种方式也是可以的。

2、  return 1 if False else 100:这样返回的是100

3、  (fun1 if 1 else fun)():选择不同的调用函数。

4、   

5、  条件表达式类似于c语言的三元表达式:C?X:Y。

6、  条件表达式的语法:X if C else y.如果C成立,这是X,否则是Y。注意:else必须有,否则编译不过;不可以是elif。

7、  用法1-赋值:

x , y = 3, 4

min = xif x < y else y

print(min)

8、  用法2-函数调用:

def fun():

    print('fun')

def fun2():

    print('fun2')

(fun if 0 else fun2)()  

其实就是所有可以使用表达式的地方。

 

排序

1、  list自己提供了排序的函数:sort。

2、  sort的参数:

a)      cmp是一个比较函数,输入两个元素,比较大小,返回值为-1,0,1.

b)     key也是一个函数,入参为一个元素,返回这个元素的关键字。

c)      reverse是一个标志位,表示升序还是降序。默认False是升序,True表示降序。

3、使用key和reverse的性能,优于cmp函数。时间是cmp函数的一半。

迭代的使用:

1、  迭代比直接使用列表遍历效率根据高。比如字典的keys函数返回的列表,以及iterkeys返回的迭代器。

2、  reversed() 内建函数将返回一个反序访问的迭代器.参数必须为序列。

3、  enumerate:返回一个迭代器:有索引值。

4、  for  eachLine  in myFile  替换   for eachLine  in myFile.readlines() :

5、  注意:在迭代的过程中不可以更改序列,否则会引发问题,导致迭代出错。

6、  可以自己定义一个类,可以迭代使用。不过需要定义方法:__iter__,next。

7、  filter(function, iterable):可以对迭代使用过滤器。

 

生成器的使用:

1、  yield关键字可以阻塞住函数的执行,并且保存当前的执行环境,整个包被称为生成器。

2、  生成器可以通过调用生成器函数来创建。生成器函数是指包含关键字yield的函数。

3、  生成器可以通过.next()来执行。每调用一次,就执行代码,直到遇到yield关键字停止,并且返回yield关键字后面的表达式的值。

4、  可以通过调用send()函数来发送消息到生成器中。a = yield l:表示将send的入参赋值给a。

5、  throw:允许客户端传入要抛出的任何异常。

6、  和throw相同,只不过是要抛出一个特定的异常:GeneratorExit。

7、  send只接受一个参数,但是可以通过传递元组的方式传递多个参数。

8、  类的方法也可以返回生成器,因为他本质上就是一个函数。

9、  在生成器使用的时候,如何获取它自身的send和nex函数?通过send二次传入是有些风险的,非常可能造成交叉引用,无法垃圾回收造成内存泄露。

10、 第一次,必须调用next来启动生成器。

11、  

a)    def fun():

b)        print(1)

c)        yield

d)        print(2)

e)        yield

f)        

g)    g = fun()

h)    cb = g.next

i)    print('-----')

j)    cb()

k)    print('-----')

l)    cb()

m)    print('-----')

上面的输出:

n)    -----

o)    1

p)    -----

q)    2

r)    -----

说明:调用第一个next函数后,才会进入函数执行,直到遇到yield为止。然后再调用下一个next的时候,执行到下一个yield。如果没有yield了,则触发一个异常。

12、  

 

装饰器的使用:

1、  装饰器本质上来说就是函数(或者是可调用对象),他们接受函数对象。装饰器仅仅用来装饰或者修饰函数的包装,返回一个修改后的函数对象,并将其赋值原来的标示符,并永久失去对原有函数的访问。

2、  什么是带参数的装饰器?其实就是一个函数,这个函数可以返回一个装饰器,同时这个函数可以接受参数。

3、  不带参数的装饰器要返回一个函数,这个函数就是用来替换原有的标示符的。

def decofun(fun):

    def _mydeco(*args,**kwargs):

        print('before fun!')

        ret =fun(*args, **kwargs)

        print('after fun', ret)

        return ret

    return _mydeco#新的函数,用于替换原有标示符

@decofun

def funtest():#funtest被替换为decofun

    print('now in funtest!')

    return 1

funtest()

4、  装饰器是可以重叠的,那么他们的顺序怎么样:

a)    @decofun2

b)    @decofun

c)    def funtest():

d)        print('now in funtest!')

e)         return 1

f)    原理是,funtest首先被decofun包装,然后再被decofun2包装。也就是,调用的时候,首先调用的是最上面的装饰器(也就是decofun2)的函数前面部分,然后再调用decofun的函数前面部分,之后再调用funtest。funtest返回后,首先调用的是decofun的函数后面部分,再调用decofun2后面部分。类似于一个栈的结构。

5、  装饰器不要滥用。如果一个装饰器只用了一次,要考虑他存在的必要了。

6、  携带参数的装饰器:

7、def decoarg(arg):

a)        def decofun3(fun):

b)            def _mydeco(*args, **kwargs):

c)                print('decoargbefore fun!', arg)

d)                ret = fun(*args, **kwargs)

e)                print('decoargafter fun', ret)

f)                return ret

g)            return _mydeco

h)        return decofun3

8、  装饰器用到的一个最重要的技术,就是闭包。装饰器函数返回的其实就是一个闭包。

9、  装饰器也可以修饰类的__方法:

class testc:

    def __init__(self):

        self.i= 1

   

    @decoarg(1)

    @decofun2

    @decofun

    def __call__(self):

        print('i is %d' % self.i)

注意:装饰器修饰类方法是无法被子类继承的(或者说子类的方法是没有被修饰的)。因为他本质上就是一个函数。

10、 装饰器也可以使对象,比如:

a)     class obj:

b)         def __init__(self,fun):

c)             self.fun =fun

d)             

e)         def __call__(self,*args, **kwargs):

f)             print('decofun before fun!', args, kwargs)

g)             ret = self.fun(*args,**kwargs)

h)             print('decofunafter fun', ret)

i)             return ret

j)     @objdeco

k)     def funtest(a, b=2):

l)         print('funtest1a , b =', a, b)

a)     这种方法看起来复杂了,但是可能会在有时候会比较有用。

 

11、 装饰器可以修饰类。这个时候装饰器接收的是一个类名,而返回的也是这个类名。它可以为这个类添加一些属性或者进行一些操作。

 

 

 

 

协程的使用:

1、  协程(coroutine)是一个可以挂起,回复,并且有多个进入点的函数。

2、   

 

 

XML的使用:

1、  处理xml消息包比较好用的模块是xml.etree.ElementTree。

2、  Element执行xml的根节点。

3、  elem.find(path):查找根节点下面路径为path的子节点。

4、  elem.findall(path):同样的子节点可能有多个,这里会返回一个列表。

5、  elem.findtext(path):获取指定路径子节点的内容,这个我们会经常使用。

6、  elem.get(key);获取属性的值。

7、  上面如果没用,则返回none

8、  elem.append:添加自节点。

9、  elem.tag:返回tag值,也就是name。

10、 elem.text:返回内容。

11、 elem.attrib:返回属性的字典。

12、 SubElement:生成一个节点,自动添加为父节点的子节点。

13、 tostring:转化为xml文本字符串。但是不包括xml头。如果编码方式为UTF-8或者GB2312,gb2312都会产生xml头;如果是utf-8,则不会产生xml头

14、 fromstring:从字符串转化为ElementTree对象。和XML同样的功能。

15、 elem.set();设置属性值

time的使用:

1、  time.sleep()函数函数具有c下sleep函数功能,单位为秒,但是可以接受浮点数。这样可以表示毫秒。

2、  ti = datetime.datetime.now()可以显示当前的时间,包括当前的微秒也可以显示出来。两个的差值可以表示时间的间隔:microsecondLong = timeLong.seconds *1000000 + timeLong.microseconds。差值的成员是seconds和microseconds

3、   

 

OO的使用:

1、  如果不想让成员变量或者方法被外部使用(也就是private特性),可以以__双下划线开通。

2、  属性不但可以定义在init中,也可以定义在任意的方法中通过self定义。不过最好在init中定义。

3、  Python也可以实现抽象基类,也就是接口:

注意:不可以对私有属性和方法执行@abstractmethod。否则会失败。因为,私有的无法被重写,所以,无法生成被实例化。

 

4、  __str__属性可以将对象转换为字符串,也就是调用print(object)是会打印的字符串。

5、  __call__(魔法方法)可以将对象作为函数来调用。给它一个入参就可以。:

    def __call__(self, protoVer):

        return api.protoModules[protoVer].TimeTicks(

            (time.time()-self.birthday)*100

            )

它的作用:比较常用的是作为回调,因为他可以保存状态信息。它和闭包类似,可能比闭包的可读性要好一点。

6、  对象实例是否可以删除?

7、  Python参考手册要好好看一下。

8、  python的static方法使用的是装饰器语法:@staticmethod.

9、  对类的调用还有一个方法:CALSS.method(object)。

10、 子类中,如果想调用父类的方法,可以通过:

parent.method(self).

不过还有更好的方法:

super(child, self).foo()//注意:这里是根据子类的类型获取父类的方法。它的好处是不用明显给出基类的类型。

11、 cls:类方法的第一个参数。通常表示类的类型,可以通过cls()来生成实例。

a)       @classmethod

b)        def spawn(cls, *args, **kwargs):

c)            """Return a new :class:`Greenlet` object, scheduled tostart.

d)     

e)            The arguments are passed to:meth:`Greenlet.__init__`.

f)            """

g)            g = cls(*args, **kwargs)

h)            g.start()

i)            return g

 

12、 继承,如果子类定义了__init__函数,子类的init函数不会默认调用父类的init函数,需要手动调用:parent.__init__。这一点是和c++有区别的。如果子类没有定义__init__,则子类会调用父类的__init__。这里可以发现,其实,子类如果定义了init函数,是对父类的init的一个覆盖。

13、 super注意:!!!它只能用在新式的类定义中。什么是新式的?原来只是基类定义时继承object!!!。

14、 继承如何继承方法:只要继承一个类,就会继承这个类所有的方法,包括__init__,__del__。但是如果子类重写某方法,就会覆盖父类的方法,不会再调用父类的方法了。如果想调用父类的方法,可以通过super的方式调用。

15、 继承如何继承属性:只要不覆盖父类__init__方法,或者调用了父类的__init__方法,就会继承父类__init__属性的方法。继承后也可以更改这些属性。

16、 父类如何防止被继承:方法或者属性以__开头,则可以防止被继承。

17、 根据我的经验,其实可以以一种本质的方式理解Python的继承:Python的类就是一些方法的集合,继承一个类就是继承这个类的所有的方法。如果在子类中定义一个方法,其实是更改了这个类的符号。而属性,则可以在所有的方法中定义,只要调用了定义属性的方法,调用父类,则是继承父类的属性,调用子类定义属性的方法,则是定义子类的方法。

18、 property:

a)    class c(object):

b)        def __init__(self):

c)            self._num = 1

d)        @property

e)        def num(self):

f)            return self._num * 10

g)        @num.setter

h)        def num(self,v):

i)            self._num = v

j)        @num.deleter

k)        def num(self):

l)            pass

m)    o = c()

n)    print(o.num)

o)    o.num = 20

p)    print(o.num)

q)    这样的好处是,可以在操作属性时,不用显示为方法调用,更加可读。同时又可以统一入口。:注意,它也必须继承object才可以。

19、 OO中的垃圾回收:Python的垃圾回收使用的是符号引用计数。那么,如果在一个函数中申请一个对象,然后返回它的一个属性或者方法,这个时候对象的符号引用已经去掉,对象是否会释放?

a)    class child(parent):

b)        def __init__(self):

c)            self.i = 8888

d)            

e)        def foo(self):

f)            print('-----------------------')

g)            

h)        def __del__(self):

i)            print('now in del child')

j)            super(child, self).__del__()

第一种情况,返回的是属性

k)     def refun():

l)         o = child()

m)         return o.i

n)     I = refun()

o)     这个时候,对象o会马上释放。因为o.i其实就是一个对象的引用,和o没有关系

第二种情况,返回的是方法

a)     def refun():

b)         o = child()

c)         return o.foo

d)     foo = refun()

e)     这个时候,对象o要等到foo释放的时候再释放,因为foo中包含了o的引用(foo的入参self)

20、 对于对象的属性,如果属性是可读写的,则第一步没有必要用@property修饰。可以直接使用。后面如果有需要,在进行修饰。这样既减少了工作,修改时,也不会对原有代码进行改动。

21、 子类无法继承父类中以“__”开始的成员。

 

模块的使用:

1、  如果不想将模块的某些函数和变量被别的模块使用,可以以单下划线开头。这样import *是没有的,但是使用importmode,然后mode._fun仍然可以调用。在class中是以双下划线开头的。

2、  使用from。。。import导入的符号,应该是本地符号,更改的话,无法更改模块中的值。可以通过mode.name=来修改。

3、  __init__.py的作用:可以这样理解:包也是一个对象,这个py就是这个包的构造函数。导入这个包,就会自动的执行__init__.py。如果在这个py中导入其他符号,import 这个包并且加*也会导入这个符号。

4、  import *无法导入模块中以_开头的符号。但是,不用*是可以的。

5、  import的本质也是创建一个符号,指向一个对象的引用。这个符号和被import的模块的符号是没有关系的。和c的extern不一样。extern可以更改变量的值,但是,这在Python中是不可以的。

from srctest import itest, outitest,setitest

import srctest

# itest = 9#这个地方其实改变的是本模块中符号的引用,无法更改srctest中对应符号。

#srctest.itest = 9#这个可以更改srctest中的itest

setitest(9)#这个可以更改srctest中的itest,但是改变不了当前模块的itest,也就是,这种设置是无法同步的。

print(itest)#打印当前模块的itest

   printitest()#打印srctest中的itest

          Python的设计哲学:看似不方便的背后,其实有Python的设计哲学。便捷性很多时候都是模块性的大敌。在软件开发中,模块间的最短路径未必是最合理路径,而且往往是最不合理路径。它会破坏软件原有的交互原则。

          Python这样设计的理由应该是,尽量将数据和对数据的操作放在一起。如果数据会扩散,那么,就将数据设计为只读的。这样有助于提高程序模块的内聚性(全局变量是内聚性的大敌),降低耦合性。降低程序的复杂性(数据只读,调试根据方便)。

         

          srctest.itest是可以改变itest的值的,说明我们可以通过改变这个对象的属性来改变对象(模块也是对象)。

   可能有一点小题大做。

6、  两个模块不可以双向import。那万一两个模块都要互相调用对方怎么办?Python的设计哲学告诉你,这不是一个好的实践,所以这样不行。应该怎么弄?一个模块调用另外一个模块,如果被调用模块想调用调用模块的方法,通过回调的形式。这样可以保证,模块间的连接都是单向的。

7、  模块间相互引用全局变量:如果采用:from mode  import vlaue的格式,引用的全局变量将会是一个新的符号,如果这个被模块的变量重新复制,引用模块中的变量不会同步更新的。这个是用可以使用import mode  的格式,然后使用mode.value形式引用。当然,不推荐模块间相互引用全局变量。会增加模块间的耦合。可以使用函数代替。

日志的使用:

1、  日志的标准模块logging基本可以满足我的工作。

2、  设置log的初始化工作:

logging.basicConfig(

    filename = "test.log",

    format = "[%(asctime)s-%(levelname)s] %(message)s[%(filename)s,%(lineno)d]",

    level = logging.INFO,

    datefmt = "%F %T")

3、  除此之外,一个比较强大的功能就是过滤功能:可以针对级别,文件,行号等等很多的东西进行过滤。

4、  自己写了一个简单的日志模块。遇到一个问题,如何获得log的文件名和行号。

看了loging模块的实现,它用了sys模块:

def fun():

    f =sys._getframe(0)

    print(f.f_back)

    co = f.f_code

    print(co.co_filename,f.f_lineno, co.co_name)

 

def fun1():

    fun()

 

fun1()

上面的代码,sys._getframe就是获取栈信息。参数0表示获取的当前函数的栈。1表示获取调用fun函数的地方。2表示调用fun1的地方。3的话会报错,没有足够的调用深度。

可以从f.f_code中获得文件名,行号,函数名。

f.f_back获取上一层的栈。

最后,这个函数可以获取上层函数的调用文件名和行号,函数:

def findCaler():

    f =sys._getframe(2)

    co = f.f_code

    return co.co_filename,f.f_lineno, co.co_name

 

 

5、  ilog(traceback.format_exc()):这句代码有问题,如果,如果traceback.format_exc()返回的字符串中包含百分号,则会导致异常。

 

自省的使用:

1、  type()可以查看对象的类型。这就是自省。也就是可以看看自己是什么类型。这个功能在动态语言中非常有用。

2、  getattr函数:这是个非常有用的函数,它可以根据字符串,从模块,类,对象实例中获取属性和方法的应用并且调用。这个功能非常类似于c语言的函数指针,以及c++中的成员函数的指针。

1)从模块中获取函数和成员

import testfun

tf = getattr(testfun, 'test')

tstr = getattr(testfun, 'str')

2)从类中获取属性和方法

class test():

    tst = 2

        def __init__(self):

        self.abc= 1

      def method(self):

        print('in test.method', self)

      def __test(self):

        print('in test')

tm = getattr(test, 'method’)#获取类方法method函数指针。因为没有实例,所以调用必须用下面的方法:

t =test()

tm(t)#申请一个实例,并且作为第一个参数传进去。

tm = getattr(test, '__test’)#这里会报错,也就是无法获取私有方法。

tabc = getattr(test, 'abc’)#这是错误的。无法获取。

ttst = getattr(test, 'tst)#这是可以的。。

 

3)从对象实例中获取属性和方法

t =test()

tm = getattr(t, 'method')

 tm()#可以这样调用,而不用传入t实例。

tabc = getattr(test, 'abc’)#可以获取实例的属性。

3、  callable:函数表示某个对象是否可以调用。它和getattr结合起来,可以获取一个对象中的所有的method列表:

methods = [methodfor method in dir[object] if callable(getattr(object, method))]

4、  自省也叫放射。

5、  exec(‘print “test”‘):可以执行字符串代码。这个特性有助于动态执行代码,可以用于机器学习,自动生成代码。

exec的参数可以使一个打开的文件对象,string,code object。

code object可以通过函数

类似的方法:execfile(filename[, globals[, locals]])。

6、  可以更改类的方法,将它指向一个新的方法。如下:

a)    class ctest():

b)        def test(self):

c)            print('c test test')

d)    def testfun():

e)        print('test fun !')

f)    c = ctest()

g)    c.test = testfun

h)     c.test()

对象c的方法test被替换为新的方法:testfun。这个特性有助于根据动态的代码实现,但是往往会增加代码的透明性。

类似的,setattr也可以实现这样的功能。delattr可以删除属性。

setattr(c, 'test', testfun)

delattr(c, 'test')

c.test()#这里调用的其实就是ctest的test方法。也就是说,delattr会首先删除setattr设置的属性,如果在调用一次delattr,才会删除c的test方法。但是如果多调用几次setattr,也只要调用一次delattr即可删除。所以,要删除一个方法,最多调用两次delattr。

这个特性可以用于动态更改代码。也可用于补丁。

setattr无法对Python的c扩展模块进行操作。

7、  如何判断一个变量是否存在:

‘v’ in dir()

‘v’ in locals()

配置文件读取的使用:

1、  使用模块ConfigParser。实例如下:

conf = ConfigParser()

conf.read("snmp_agent.ini")

 

print(conf.get("main", "log_level"))

print(conf.getint("main", "ne_agent_port"))

print(conf.get("main", "ne_agent_qip"))

 

异常的使用:

1、  尽量少用。它会使程序难以理解,而且还会发生不可预知的情况,比如异常的发生使程序的状态变为一个未知状态。

2、  可以寻找替代方案。

3、  程序非常重要,不可以停止,可以在主循环包装在异常处理中运行。

4、  打印出异常的信息,供后面的定位:log.error(traceback.format_exc())

5、  raise在引发异常的时候,可以传递引发一场的额外数据。形式如下:

raise Exception,1

捕获方法:

except CallExit,e:

e就是那个额外数据1。(但是奇怪的是它的类型不是1)

6、  如何捕获一个异常,进行处理,然后在把它抛出:

    except :

        for flet in fletList:

            flet.throw()

        info = sys.exc_info()

       raise info[0], info[1], info[2]

7、  如何使用异常才是Pythonic的做法?这个要看一下。

8、 

9、  xcept (Exc1[, Exc2[, ... ExcN]])[, reason]: 可以处理多个异常

    suite_for_exceptions_Exc1_to_ExcN

10、 捕获所有异常

try:

    :

except Exception, e:

# error occurred, log 'e', etc.

11、 先捕获指定,再捕获所有

 

try:

    :

except (KeyboardInterupt, SystemExit):

    # user wants to quit

    raise    # reraise back to caller

except Exception:

    # handle real errors

12、  KeyboardInterrupt 和 SystemExit 被从 Exception 里移出, 和 Exception 平级。

a)      try:

b)         :

c)      except (KeyboardInterupt,SystemExit):

d)         # user wants to quit

e)         raise   # reraise back to caller

f)      except Exception:

g)          # handle real errors

13、  在 try 范围中没有异常被检测到时,执行 else 子句

a)      try:

b)         3rd_party_module.function()

c)      except:

d)         log.write("*** caught exception inmodule\n")

e)     else:

f)          log.write("*** no exceptionscaught\n")

14、 finally 子句是无论异常是否发生,是否捕捉都会执行的一段代码.你可以将 finally 仅仅配合try一起使用,也可以和try-except(else也是可选的)一起使用.

15、 .try-finally语句 try 中是否有异常触发,finally 代码段都会被执行

a)      try-except-else-finally:

b)     with语句:

c)      with context_expr [as var]:

d)         with_suite

16、 raise [SomeException [, args [, traceback]]] 。args 可以使一个元组。如果是一个对象,则它会把它封装成一个元组。

try:

    raise Exception, 1

except Exception, e:

  print(e)

  if e == 1://这是不可以的。e的类型是一个特殊的对象。正确的应该是:if e[0] == 1

print('\n222222222')

17、 标准异常:

18、  

19、  

类型系统

1、  类型也是对象。比如:inttype = int,然后,n = inttype(‘256’),这样可以把字符串转化为int值。

2、  另外,是否可以把字符串转化为关键字,或者对象?比如,一个变量,abc,是否可以通过’abc’来引用?

OS的使用

os中有很多可以直接利用的东西,比如,判断文件是否存在,删除文件等。这样可以不用再执行shell命令。

os.rremove(path):删除文件

os.system(‘ls’);执行shell命令

文件的使用

1、  打开使用函数open,模式和linux c类似。有一个不同的地方时,可以选择,直接操作磁盘还是操作内存。

2、  readline可以读取一个文件的一行。

3、  readlines:返回每一个列的列表。对应writelines。

4、  文件迭代器:

f = open(‘fliename’)

for line in f:

    process(line)

          f.close()

          或者更简洁的:

          forline in open(filename):

                     process(line)

5、  文件迭代器的使用:

如果文件很大,readlines可能会占用过多的内存。所以,Python提出一种类似于惰性求值的惰性迭代。

有两种方案:fileinput和文件迭代器:

import fileinput

for line infileinput.input(filename)

            process(line)

文件迭代器:

f =open(filename)

for line in f:

            process(line)

6、  如何判断文件是否存在:

import os

os.path.isfile('/home/keepshell')

os.path.exists('/home/keepshell')

7、  如何判断目录是否存在:

import os

os.path.isdir('/home')

os.path.exists('/home')

8、  遍历目录路径:os.listdir(‘/home’),返回值是一个列表。

9、  basename:去掉目录名,返回文件名;dirname:去掉文件名,返回目录名。

 

 

数据库的使用

1、  数据库中的字段使用的utf8格式编码,但是读取出来却是问号。这个问题的解决可以通过在查询的时候指定编码方式来解决,只要执行sql语句:Query_Execsql(pdb,"SET NAMES 'utf8'");

注意,这个需要在连接后马上进行。并且,在其他的操作中,会一直使用这种编码。除非再次更改。

2、  fetchone():返回一条记录。fetchall():返回所有的记录。

3、  可以使用一个简单的方法获取所有的记录:

cur.execute(sql)

for tel, name, pwd in cur:

       print tel, name, pwd

FTP的使用

Python的标准模块ftplib就可以支持FTP。

几个函数:

FTP(host='', user='', passwd='', acct='',               timeout=_GLOBAL_DEFAULT_TIMEOUT):如果参数中有user,则Connect();如果同时也有user,则login()。如果没用这些参数,后要自己调用connect和login。

connect(self, host='', port=0,timeout=-999):如果端口不是标准端口,则要手动调用connect。

login(user = '', passwd = '', acct =''):登陆。

pwd():获得当前的工作路径。

cwd(path):更改当前的工作路径。

dir(path,cb):显示目录中的内容。cb为文件的处理函数。会传递给retrlines。这个函数可以获取一个目录下的所有的内容。

retrlines(self, cmd, callback =None):下载文本文件。cmd的形式为“RETR FILENAME”,callback是一个函数,要处理文本文件的每一个行。这里一个问题,如果直接用file的write方法,则会丢失换行符。而又没有writeline函数。

retrbinary(self, cmd, callback,blocksize=8192, rest=None):下载二进制文件,cmd的形式为“RETR FILENAME”,callback是一个函数,要处理文本文件的每一个块。默认大小事8k,但是可以更改。

storlines(self, cmd, fp,callback=None):上传文本文件。cmd的形式为“STOR FILENAME”。fp是一个文件对象,必须有readline方法。callback:每传送一行,就会调用这个函数。

storbinary(self, cmd, fp,blocksize=8192, callback=None, rest=None): 上传二进制文件。cmd的形式为“STOR FILENAME”。fp是一个文件对象,必须有read(num_bytes)方法。默认大小事8k,但是可以更改。

quit():退出。

字节的使用

1、  ord:可以见字符转化为int类型的值。

2、  chr:ord的方向操作。可以见int类型值转换为字符。

 

处理二进制

1、  由字符串转化为字节流:bytes = struct.pack('!2B2s2B2s2B2s', 3, 1, '11', 3, 1, '22', 3, 1,'22')

2、  处理后的字节流也可以使用字符串处理函数。

3、   

字符编码的使用

1、  encode是将Unicode转化为str,decode是将字符串转化为Unicode。所以,一个字符串要转化为另一种格式可以:

s = ‘中文’

s.decode(fromcodec).encode(tocodec)

也可以直接使用:s.encode(tocodec)。这个时候,相当于默认调用了decode,并且使用的是默认的编码方式。

 

2、  直接对一个Unicode文本调用str()函数的时候可能会报错:ASCII不支持等等。原因是默认的编码方式ASCII,不支持多字节。可以通过更改默认的编码方式来解决:

reload(sys)

sys.setdefaultencoding('gb2312')

3、  新的内建函数unicode()和unichar()可以看成Unicode版本的str()和chr().Unicode()函数可以把任何 Python 的数据类型转换成一个 Unicode 字符串

4、  核心编程中的建议。核心编程这本书不错,要好好看看。

a)      程序中出现字符串时一定要加个前缀u.

b)     不要用 str()函数,用 unicode()代替.

c)      不要用过时的 string 模块 -- 如果传给它的是非 ASCII 字符,它会把一切搞砸。

d)     不到必须时不要在你的程序里面编解码 Unicod 字符.只在你要写入文件或数据库或者

e)     网络时, 才调用encode()函数;相应地,只在你需要把数据读回来的时候才调用decode()

f)      函数.

5、  epoll.register函数中的event需要使用“|”来将多个事件并联起来。它应该是使用的其中的一位。

6、  epoll.poll函数返回套接字,事件。这个事件中可能含有多个事件,是以位的形式表示的。所以判断是否有某个事件,需要使用:event & select.EPOLLOUT。

7、   

源码安全与发布

1、  Python代码如果直接发布,可能会暴露源码。

2、  一个方法是利用c扩展Python,来代替核心模块。

3、  另一个折中的方法就是对源码进行编译,生成pyc或者pyo文件。这些事字节码文件。可能会被反编译。所以,可能需要研究一下Python的pyo生成和加载方式,来生成更安全的Python字节码。网上说可以修改Python源码的opcode。没有研究过。

4、  命令:python -m compileall。

5、  也可以在Python中使用:

a)     import compileall

b)      

c)     compileall._dir('Lib/',force=True)

d)      

e)     # Perform same compilation, excluding files in .svn directories.

f)     import re

g)     compileall._dir('Lib/',rx=re.compile('/[.]svn'), force=True)

h)      

6、  程序发布:可以使用zip对所有的源文件进行打包。zip包中需要有一个入口文件:__main__.py,然后就可以使用Pythontest.zip来执行程序。

GC

1、  OO中的垃圾回收:Python的垃圾回收使用的是符号引用计数。那么,如果在一个函数中申请一个对象,然后返回它的一个属性或者方法,这个时候对象的符号引用已经去掉,对象是否会释放?

a)    class child(parent):

b)        def __init__(self):

c)            self.i = 8888

d)            

e)        def foo(self):

f)            print('-----------------------')

g)            

h)        def __del__(self):

i)            print('now in del child')

j)            super(child, self).__del__()

第一种情况,返回的是属性

k)     def refun():

l)         o = child()

m)         return o.i

n)     I = refun()

o)     这个时候,对象o会马上释放。因为o.i其实就是一个对象的引用,和o没有关系

第二种情况,返回的是方法

f)     def refun():

g)         o = child()

h)         return o.foo

i)     foo = refun()

j)     这个时候,对象o要等到foo释放的时候再释放,因为foo中包含了o的引用(foo的入参self)

k)       

2、  如果两个对象交叉引用,是否会自动回收?不会。同样,如果一个对象把生成的对象赋值给它自身的一个属性,那么它也不会自动回收。

3、   

 

c扩展

1、  可以使用swig来创建c 的扩展程序,非常方便。目前没有时间研究内部机制,先暂时使用,后面在研究吧。

2、  swig使用步骤:为库的头文件建立.i文件:

%{

/* Includes theheader in the wrapper code */

#include"code.h"

#include"sip.h"

%}

 

/* Parse theheader file to generate wrappers */

%include"code.h"

%include"sip.h"

3、  使用swig命令生成py脚本及对应的C文件:swig –python sip.i。

4、  将生成的c源文件放到c扩展库中进行编译。

5、  这里有一个要注意:生成的动态链接库,必须是_sip.so,否则无法调用。swig是写死的。_sip.so需要拷贝到:/usr/local/lib/python2.7/site-packages/路径下。

6、  Makefile文件中,对于库引用的其他的库,必须显示的指出,否则Python无法找到对应的库。

7、  如何在c的扩展库中调用Python的函数:

swig是不支持直接在c的扩展库中调用Python函数的。它只支持将C的接口作为回调函数设置给c的库。

实现这个功能需要利用Python的c API和ctypes来实现。

Python c 的api包含一系列的函数:

PyCallable_Check:检查对象是否可调用;

PyArg_ParseTuple:解析参数列表,将Python参数解析为c;

PyEval_CallObject:调用对象;

Py_BuildValue:将c变量打包为Python的参数对象。

好了,有这些就足够了。

假设c库中有一个设置回调函数接口:

void set_callback_fun(void(*fun)(int, int , int))

{

}

下面是c扩展库中要添加的代码:

//全局变量,保存Python中要回调的可调用对象。

static PyObject*gCallbackFun = NULL;

 

//调用上面函数设置的python脚本函数

//Python可调用对象的转换函数,转化为C的调用方式

static voidcallbacfun(int type,int chn,int dataType)

{

    PyObject* pArgs = NULL;

    PyObject* pRetVal = NULL;

    int   nRetVal = 0;

   

    pArgs = Py_BuildValue("(i, i,i)", type, chn, dataType);//将c的参数转化为Python的参数对象

    pRetVal = PyEval_CallObject(gCallbackFun,pArgs);//调用Python的可调用对象。

    Py_DECREF(pArgs);

    Py_DECREF(pRetVal);

}

 

/// set_callback_fun函数的包装函数

static PyObject*wrap_set_callback_fun(PyObject *dummy, PyObject *args)

{

    PyObject *temp = NULL;

 

    if (PyArg_ParseTuple(args, "O:set_callback_fun",&temp)) {//获取Python对象

        if (!PyCallable_Check(temp)) {//检查对象是否可以调用

            PyErr_SetString(PyExc_TypeError,"parameter must be callable");

        }

    Py_XINCREF(temp);         /* Add a reference to new callback */

    Py_XDECREF(gCallbackFun); /* Dispose ofprevious callback */

    gCallbackFun = temp;       /* 保存回调对象 */

    }

   

    set_callback_fun(callbacfun);//注意,这里掉一下包,用一个C的函数注册到c库中。

   

    return Py_BuildValue("i",(gCallbackFun == NULL) ? 0 : 1);

}

 

注意:如果对象不可调用,会段错误。后面要解决一下。

 

Python代码:

   CBFUNC  =CFUNCTYPE(c_int, c_int, c_int, c_int)//创建一个c函数类型的对象工厂,该函数返回值为int,有三个入参,都为int。

callbakFunc = CBFUNC(pyFun)//根据Python可调用对象生成函数。

set_callback_fun(callbakFunc)//设置回调函数

注意:pyFun必须要有返回值。否则会报异常。

另外,我发现,不用CFUNCTYPE来生产c回调函数,直接用pyFun,也是可以的。至于区别,后面在研究一下吧,要写代码了。

        几个异常问题:1、一个可以使用CFUNCTYPE,但是一个一使用它就段错误。2、回调函数可以不返回值,也是可以的。但是一个不返回就不可以。

在Python中使用c扩展时向C传递数组:

 

8、  如果一个函数的参数是一个数组(指针),Python如何传递?下面的方法是可以直接传递列表。把这个加到.i文件中。

%{

static intconvert_darray(PyObject *input, int *ptr, int size) {

  int i;

  if (!PySequence_Check(input)) {

     PyErr_SetString(PyExc_TypeError,"Expecting a sequence");

      return 0;

  }

  if (PyObject_Length(input) != size) {

     PyErr_SetString(PyExc_ValueError,"Sequence size mismatch");

      return 0;

  }

  for (i =0; i < size; i++) {

      PyObject *o =PySequence_GetItem(input,i);

      if (!PyFloat_Check(o)) {

         Py_XDECREF(o);

        PyErr_SetString(PyExc_ValueError,"Expecting a sequence offloats");

         return 0;

      }

      ptr[i] = PyFloat_AsDouble(o);

      Py_DECREF(o);

  }

  return 1;

}

%}

%typemap(in) int[ANY](int temp[$1_dim0]) {

   if (!convert_darray($input,temp,$1_dim0)) {

      return NULL;

   }

   $1 = &temp[0];

}

9、  如果一个结构体中有一个int类型数组,应该如何赋值?

在.i中增加下面代码:

%include"carrays.i"

%array_class(int,intArray);

在Python中申请数组:

a = intArray(10),将A复制给数组成员即可。

 

代码错误检查

1、  今天遇到两个问题:

a)      类中方法:class_registerEvent(notifyEvent): def _sendRegRsp(self, voiceres, reqId, result,reason,status):,调用时参数个数少一个:self._sendRegRsp(voiceres,reqId, 'success', 'normal')   。结果是没有任何提示,并且,不知道调用了什么函数。这个问题有点匪夷所思。后面好好查看一下。

b)     抽取函数后,有时忘了返回值,当时却用到了返回值:

              i.          def createWirelessSdp(voiceRtpPort, voiceTbcpPort):

           ii.              voicesdp = SIP_SDP()

                iii.              voicesdp.a_use = 1

               iv.          sdp = createWirelessSdp(1000,2000)

                v.          结果也是没有任何提示,sdp为None。

 

2、  总结:写Python代码,需要使用代码检查工具,比如,pylint等。后面引进一下。

程序运行

1、  如何获取命令行参数:

a)    import sys

b)     

c)      print(sys.argv[1])

d)     sys.argv[1]就是第一个参数。0是脚本的名称。

 

代码调试

1、  自己摸索的一个方法:

1、gdbpython

2、run

3、importtest.py

这里注意一下,这个脚本是主流程脚本。没有if __name__ == "__main__".



 

 

 

关于性能

1、  timeit:可以统计程序的运行时间。目前没有时间,抽时间好好看看。

timeit(cut1,number=10000):cut1是函数名,number是执行次数。

2、  pypy可以将Python代码翻译为可执行程序,它的效率可以提高4倍左右。但是,内存的占用可能会很大。(没有试过。)

3、  使用字典代替列表:字典内部使用哈希,比列表的迭代更快。

4、  使用set集合代替列表:set内部也使用哈希,而且set的求差集交集也非常快。

5、  字符串优化:

a)      join比+要快。

b)     当对字符串可以使用正则表达式或者内置函数来处理的时候,选择内置函数。如str.isalpha(),str.isdigit(),str.startswith((‘x’, ‘yz’)),str.endswith((‘x’, ‘yz’))

c)      对字符串格式化比直接串联格式化要快。

d)      

6、  列表解析比使用循环构造一个列表根据高效。

7、  生成器表达式则是在2.4中引入的新内容,语法和列表解析类似,但是在大数据量处理时,生成器表达式的优势较为明显,它并不创建一个列表,只是返回一个生成器,因此效率较高。它的语法是:(a for a in xrang(100) if a != 1)

8、  如果需要交换两个变量的值使用a,b=b,a而不是借助中间变量t=a;a=b;b=t;

9、  使用xrange而不是range。

10、 避免使用global关键字,访问全局变量要比访问局部变量慢很多。

11、 if done is not None比语句if done!=None更快。if done is noe 比 if done == None更快。

12、 在耗时较多的循环中,可以把函数的调用改为内联的方式;

13、 使用级联比较 “x < y < z”而不是“x < y and y < z”;

14、 while 1要比while True更快(当然后者的可读性更好);

15、 build in函数通常较快,add(a,b)要优于a+b。

16、 Python内置了丰富的性能分析工具,如profile,cProfile与hotshot。

17、 Python的性能优化工具:Psyco,Pypy,Cython,Pyrex。

18、 from a import b 引用b比a.b引用b要快。

 

优化的原则是,首先找到整个系统的瓶颈(源于80/20原则)。然后使用优化工具进行优化。有两个比较看好,分别是Cython(可以用来写Python的c扩展)和pypy(一个新的解释器)。

pypy目前不支持cpython的c扩展。如果使用纯Python是可以使用pypy的。但是如果使用了c扩展,则可能要使用cython来优化。

 

切忌:不要提前优化,这是万恶之源。

 

如果知道了上面这几条是“为什么”,那我对Python的认识就又提高一个层次了。下一阶段的目标。

 

其他:

1、  脚本语言的进程名称显示为:python ,如果一个服务器上有多个进程,那么将不易发现那个进程是哪个程序。可以使用第三方开源的库来解决这个问题:setproctitle.

from setproctitle import setproctitle,getproctitle

print('当前的进程名:%s' % getproctitle())

setproctitle('proctitle')

print('设置后的的进程名:%s' % getproctitle())

2、  with语法:with open(‘file’, ‘r’)as f:

code

可以是try的另一种形式。

          可以执行with操作的类型:

file

decimal.Context

thread.LockType

threading.Lock

threading.RLock

threading.Condition

threading.Semaphore

threading.BoundedSemaphore

3、  产生随机数:random.randint(100000, 999999)。choice会返回序列的一个随机元素。

4、  回调函数的使用:设置回调函数的时候,很多时候要使用闭包。避免闭包的一个方法是:

a)    def setCancelFun(cancelFun, *args, **kwargs):

b)        '''如果为None表示删除取消函数, 后面跟的是cancel函数的参数。这样可以避免上面创建闭包。'''

c)        global _cancelFun,_cancelArgs,_cancelKwargs

d)        _cancelFun = cancelFun

e)        _cancelArgs = args

f)        _cancelKwargs = kwargs

g)     

h)    def __execCancelFun():

i)        '执行取消操作。因为在throwkill的时候会执行此函数,所以,暂时没有看到会在外面调用此函数。屏蔽后,接口的简单性会提高'

j)        global _cancelFun,_cancelArgs,_cancelKwargs

k)        if callable(_cancelFun):

l)            _cancelFun(*_cancelArgs,**_cancelKwargs)

m)            _cancelFun = None#防止重复调用

n)     

o)    def test(a,b, c):

p)        print('--------test:', a,b,c)

q)     

r)    setCancelFun(test, 1, 2, 3)

s)      __execCancelFun()

也就是增加可变参数。

 

 

Python:一切皆符号?

 

 



查看全文
如若内容造成侵权/违法违规/事实不符,请联系编程学习网邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!

相关文章

  1. Android集成百度TTS,实现离在线的中英语音合成

    百度的离在线TTS,没有调用量限制,免费但是有QPS限制(是对一个特定的查询服务器在规定时间内所处理流量多少的衡量标准),增大QPS需要收费,所以对商用并不是很好友。如果想用完全免费的纯离线可参考我另一篇博客: https://blog.csdn.net/sunyFS/article/details/97936551 …...

    2024/4/28 5:36:43
  2. Android学习笔记(十四)-简易音频播放器

    在Android中可以使用MediaPlayer来播放音频,常见使用方法如下:MediaPlayer mediaPlayer = new MediaPlayer(); if (mediaPlayer.isPlaying()) {mediaPlayer.reset();//重置为初始状态 } mediaPlayer.setDataSource("/mnt/sdcard/god.mp3"); mediaPlayer.prepare();…...

    2024/4/28 4:13:53
  3. Heritrix提高抓取效率的若干尝试

    一.利用ELFHash策略多线程抓取网页这些天看了其它小组的博客,发现大家用Heritrix抓取所花的时间都比较长,基本都要花上数天的时间才能抓完,名副其实的爬虫…之所以这么慢,一个重要的原因是heritrix在抓取时一般只运行了一个线程。在网上查找原因,得知这是因为在默认的情况…...

    2024/4/12 17:24:05
  4. 方立勋_30天掌握JavaWeb_Web开发入门

    WEB开发的相关知识WEB,在英语中web即表示网页的意思,它用于表示Internet主机上供外界访问的资源。Internet上供外界访问的Web资源分为: 静态web资源(如html 页面):指web页面中供人们浏览的数据始终是不变。动态web资源:指web页面中供人们浏览的数据是由程序产生的,不同…...

    2024/4/28 3:48:30
  5. 网络爬虫Heritrix1.14.4在MyEclipse中的安装配置与使用教程

    本文主要参考:http://blog.csdn.net/yunshuixiliu/article/details/8627488 和http://blog.csdn.net/wy_kath/article/details/9385015 非常感谢!!!记下来,以便以后查看~一、heritrix的安装配置Heritrix具体下载地址如下:http://sourceforge.net/projects/archive-crawl…...

    2024/4/28 1:20:33
  6. 百度语音合成TTS

    百度语音合成TTS3 百度语音合成一段十秒左右的音频的文字限制 3 百度语音合成一段十秒左右的音频的文字限制 Baidu Online TTS 10秒语音文字限制: Test Text:假如生活欺骗了你, 不要悲伤,不要心急! 忧郁的日子里须要镇静: 相信吧,快乐的日子将会来临! 心儿永远向往着未…...

    2024/4/12 17:25:01
  7. Android学习笔记(20)---UI界面被输入法遮挡问题

    1、在Android系统中,有时候在文本框中输入文字后,操作按钮被输入法遮挡了,不得不关闭输入法才可以继续操作。默认时时这样的,很麻烦。 2、于是,查了一些资料,终于找到方法。 先来看下代码与效果: <?xml version="1.0" encoding="utf-8"?> &…...

    2024/4/28 1:16:08
  8. Java Web 视频教程(推荐)

    搜集到的视频资源,自己以前看过,觉得主讲老师讲解得非常好,所以推荐给大家JavaWeb 基础: JSP、Javascript、jQuery、Ajax、JSONSSH框架: Struts2、SpringUnit Test: JUnitAnt 下载地址:Java Web 转载于:https://www.cnblogs.com/leezk/p/3341073.html...

    2024/4/12 17:24:56
  9. 【Java学习】eclipse,javaWeb项目的一些技巧,经验总结,持续更新

    1.有时候在查看jsp页面时,页面代码太乱。怎么办呢???可以通过 ctrl+shift+f 快捷键,来格式化代码。2.格式化jsp代码的时候,一行jsp标签代码太长。格式化后出现换行。怎么办呢?这是由于eclipse默认设置中,默认一行jsp代码为72长度步骤: Window->Preferences->Web…...

    2024/4/14 0:16:54
  10. Android学习笔记系列教程集合

    首页 | Android初级 | Android资料 |Android进阶 |Android源码 |Android书籍 |Android游戏开发Android是由谷歌在2007年推出的一个开放系统平台,主要针对移动设备市场,目前版本为Android 4.0。Android基于Linux,开发者可以使用Java或C/C++开发Android应用。本专题将为大家详…...

    2024/4/19 9:12:52
  11. python 调用阿里云语音合成TTS

    #!/usr/bin/env python # -*- coding:utf-8 -*- import hashlib import requests import hmac import base64 import datetime import tempfile import shutil,osclass aliyun:def __init__(self):self.__aliyun_id = "" # 个人用户 idself.__aliyun_secret = "…...

    2024/4/12 17:25:06
  12. Heritrix启动过程

    Heritrix启动过程调用org.archive.crawler.Heritrix.main(String[])启动工程 containerInitialization();方法初始化容器,里面包含 //读取heritrix.properties配置文件信息 Heritrix.loadProperties(); //设定日志文件写入位置(heritrix_dmesg.log) Her…...

    2024/4/12 17:25:06
  13. 嵩天老师的中国大学排名定向爬虫实例-萌新教程

    萌新实例,大佬们可以右上角了, 萌新可以看看互相学习我是在是学习了《Python简明教程》还有廖雪峰老师的《Python3教程》后,才发现嵩天老师的视频的,简洁、生动、有趣,有时候还挺萌的,要是能早点知道嵩天老师,我觉的学习时间应该能减少少一半,不是说其他的不好,只是更…...

    2024/4/20 7:34:19
  14. 微软软件工程 第一周博客作业

    1. 自我介绍 时隔1年, 我又上了这门软件工程课, 只是上课地点还有老师助教发生了变化, 之前在科大,邓金宏老师,现在在微软亚洲研究院,著名的邹欣老师。传说邓老师就是被我们这届科大的软件工程课学生给“气“走的, 邹欣老师可要小心了,哈哈哈。 我叫黄志鹏,是中科大16…...

    2024/4/12 17:24:51
  15. IT兄弟连 JavaWeb教程 EL表达式中的运算

    EL语言支持算符运算符、关系运算符和逻辑运算符等,以完成常见的数据处理操作。所有的运算符说明见表7.2。 表2 El表达式中的运算符转载于:https://www.cnblogs.com/itxdl/p/10843286.html...

    2024/4/18 15:42:14
  16. 关于heritrix安装配置时出现"必须限制口令文件读取访问权限"的解决方法

    最近开始写一个RSS聚合程序,需要爬虫支持,于是就整来heritrix,没想到,这东西还挺拽,费了老衲好几个小时来安装配置这个heritrix。最后经过不懈努力,终于起来了,具体步骤如下: 你如果在网上找相关配置,大多数都是讲先修改conf/properties文件的用户名和密码以及修改jmx…...

    2024/4/20 15:07:07
  17. Python IDLE入门 + Python 电子书

    Python IDLE入门http://www.cnblogs.com/dsky/archive/2012/06/04/2535397.html#提示用户输入 integer1 = raw_input(请输入一个整数:) integer1 = int(integer1) integer2 = raw_input(请再次输入一个整数:) integer2 = int(integer2) if integer1>integer2:print %d >…...

    2024/4/12 17:25:01
  18. 我的Java之路--Android转Java后台

    作为一个资深Android程序猿,现正在Java的道路上砥砺前行。。。 刚入职目前公司不久,领导宣布Android项目停止,全力投入到对公司主站的改造上,公司主站是Java项目,我也就开始了Java开发。说实在的,由Android转Java还是有一定难度的,虽然都是java语言,但编码思维完全不同…...

    2024/4/19 15:11:19
  19. Android调用自带TTS文本转语音引擎实现离线语音合成

    只要手机带有语音助手的话一般就会存在中文语音引擎,如果没有的话需要额外下载中文的语音引擎,不然不支持中文。开工,第一步,初始化:private TextToSpeech tts; tts = new TextToSpeech(this, new TextToSpeech.OnInitListener() {@Overridepublic void onInit(int status…...

    2024/4/19 20:03:24
  20. 在.NET中使用DirectShow

    下载源程序:【北方网通】 【电信或网通】 【下载说明】 1、单击上面这个地址,打开下载页面。 2、点普通下载--等待30秒--点“下载”按钮--保存摘要这个实验性的代码展示了怎么在C#中使用DirectShow技术。它包含一个简单的媒体播放器、DVD播放器、抓取视频画面至硬盘和简单的…...

    2024/4/16 23:22:24

最新文章

  1. 前端HTML5学习2(新增多媒体标签,H5的兼容性处理)

    前端HTML5学习2新增多媒体标签&#xff0c;H5的兼容性处理&#xff09; 分清标签和属性新增多媒体标签新增视频标签新增音频标签新增全局属性 H5的兼容性处理 分清标签和属性 标签&#xff08;HTML元素&#xff09;和属性&#xff0c;标签定义了内容的类型或结构&#xff0c;而…...

    2024/4/28 7:08:54
  2. 梯度消失和梯度爆炸的一些处理方法

    在这里是记录一下梯度消失或梯度爆炸的一些处理技巧。全当学习总结了如有错误还请留言&#xff0c;在此感激不尽。 权重和梯度的更新公式如下&#xff1a; w w − η ⋅ ∇ w w w - \eta \cdot \nabla w ww−η⋅∇w 个人通俗的理解梯度消失就是网络模型在反向求导的时候出…...

    2024/3/20 10:50:27
  3. AI小程序的创业方向:深度思考与逻辑引领

    随着人工智能技术的快速发展&#xff0c;AI小程序逐渐成为创业的新热点。在这个充满机遇与挑战的时代&#xff0c;我们有必要深入探讨AI小程序的创业方向&#xff0c;以把握未来的发展趋势。 一、目标市场定位 首先&#xff0c;我们要明确目标市场。针对不同的用户需求&#x…...

    2024/4/27 11:03:33
  4. 【JavaScript 漫游】【049】ES6 规范中对象的扩展

    文章简介 本篇文章为【JavaScript 漫游】专栏的第 049 篇文章&#xff0c;对 ES6 规范中对象的扩展知识点进行了记录。具体包括&#xff1a; 属性的简洁表示法属性名表达式方法的 name 属性属性的可枚举性和遍历super 关键字对象的扩展运算符链判断运算符Null 判断运算符新增…...

    2024/4/23 21:45:44
  5. 【外汇早评】美通胀数据走低,美元调整

    原标题:【外汇早评】美通胀数据走低,美元调整昨日美国方面公布了新一期的核心PCE物价指数数据,同比增长1.6%,低于前值和预期值的1.7%,距离美联储的通胀目标2%继续走低,通胀压力较低,且此前美国一季度GDP初值中的消费部分下滑明显,因此市场对美联储后续更可能降息的政策…...

    2024/4/26 18:09:39
  6. 【原油贵金属周评】原油多头拥挤,价格调整

    原标题:【原油贵金属周评】原油多头拥挤,价格调整本周国际劳动节,我们喜迎四天假期,但是整个金融市场确实流动性充沛,大事频发,各个商品波动剧烈。美国方面,在本周四凌晨公布5月份的利率决议和新闻发布会,维持联邦基金利率在2.25%-2.50%不变,符合市场预期。同时美联储…...

    2024/4/28 3:28:32
  7. 【外汇周评】靓丽非农不及疲软通胀影响

    原标题:【外汇周评】靓丽非农不及疲软通胀影响在刚结束的周五,美国方面公布了新一期的非农就业数据,大幅好于前值和预期,新增就业重新回到20万以上。具体数据: 美国4月非农就业人口变动 26.3万人,预期 19万人,前值 19.6万人。 美国4月失业率 3.6%,预期 3.8%,前值 3…...

    2024/4/26 23:05:52
  8. 【原油贵金属早评】库存继续增加,油价收跌

    原标题:【原油贵金属早评】库存继续增加,油价收跌周三清晨公布美国当周API原油库存数据,上周原油库存增加281万桶至4.692亿桶,增幅超过预期的74.4万桶。且有消息人士称,沙特阿美据悉将于6月向亚洲炼油厂额外出售更多原油,印度炼油商预计将每日获得至多20万桶的额外原油供…...

    2024/4/27 4:00:35
  9. 【外汇早评】日本央行会议纪要不改日元强势

    原标题:【外汇早评】日本央行会议纪要不改日元强势近两日日元大幅走强与近期市场风险情绪上升,避险资金回流日元有关,也与前一段时间的美日贸易谈判给日本缓冲期,日本方面对汇率问题也避免继续贬值有关。虽然今日早间日本央行公布的利率会议纪要仍然是支持宽松政策,但这符…...

    2024/4/27 17:58:04
  10. 【原油贵金属早评】欧佩克稳定市场,填补伊朗问题的影响

    原标题:【原油贵金属早评】欧佩克稳定市场,填补伊朗问题的影响近日伊朗局势升温,导致市场担忧影响原油供给,油价试图反弹。此时OPEC表态稳定市场。据消息人士透露,沙特6月石油出口料将低于700万桶/日,沙特已经收到石油消费国提出的6月份扩大出口的“适度要求”,沙特将满…...

    2024/4/27 14:22:49
  11. 【外汇早评】美欲与伊朗重谈协议

    原标题:【外汇早评】美欲与伊朗重谈协议美国对伊朗的制裁遭到伊朗的抗议,昨日伊朗方面提出将部分退出伊核协议。而此行为又遭到欧洲方面对伊朗的谴责和警告,伊朗外长昨日回应称,欧洲国家履行它们的义务,伊核协议就能保证存续。据传闻伊朗的导弹已经对准了以色列和美国的航…...

    2024/4/28 1:28:33
  12. 【原油贵金属早评】波动率飙升,市场情绪动荡

    原标题:【原油贵金属早评】波动率飙升,市场情绪动荡因中美贸易谈判不安情绪影响,金融市场各资产品种出现明显的波动。随着美国与中方开启第十一轮谈判之际,美国按照既定计划向中国2000亿商品征收25%的关税,市场情绪有所平复,已经开始接受这一事实。虽然波动率-恐慌指数VI…...

    2024/4/27 9:01:45
  13. 【原油贵金属周评】伊朗局势升温,黄金多头跃跃欲试

    原标题:【原油贵金属周评】伊朗局势升温,黄金多头跃跃欲试美国和伊朗的局势继续升温,市场风险情绪上升,避险黄金有向上突破阻力的迹象。原油方面稍显平稳,近期美国和OPEC加大供给及市场需求回落的影响,伊朗局势并未推升油价走强。近期中美贸易谈判摩擦再度升级,美国对中…...

    2024/4/27 17:59:30
  14. 【原油贵金属早评】市场情绪继续恶化,黄金上破

    原标题:【原油贵金属早评】市场情绪继续恶化,黄金上破周初中国针对于美国加征关税的进行的反制措施引发市场情绪的大幅波动,人民币汇率出现大幅的贬值动能,金融市场受到非常明显的冲击。尤其是波动率起来之后,对于股市的表现尤其不安。隔夜美国股市出现明显的下行走势,这…...

    2024/4/25 18:39:16
  15. 【外汇早评】美伊僵持,风险情绪继续升温

    原标题:【外汇早评】美伊僵持,风险情绪继续升温昨日沙特两艘油轮再次发生爆炸事件,导致波斯湾局势进一步恶化,市场担忧美伊可能会出现摩擦生火,避险品种获得支撑,黄金和日元大幅走强。美指受中美贸易问题影响而在低位震荡。继5月12日,四艘商船在阿联酋领海附近的阿曼湾、…...

    2024/4/28 1:34:08
  16. 【原油贵金属早评】贸易冲突导致需求低迷,油价弱势

    原标题:【原油贵金属早评】贸易冲突导致需求低迷,油价弱势近日虽然伊朗局势升温,中东地区几起油船被袭击事件影响,但油价并未走高,而是出于调整结构中。由于市场预期局势失控的可能性较低,而中美贸易问题导致的全球经济衰退风险更大,需求会持续低迷,因此油价调整压力较…...

    2024/4/26 19:03:37
  17. 氧生福地 玩美北湖(上)——为时光守候两千年

    原标题:氧生福地 玩美北湖(上)——为时光守候两千年一次说走就走的旅行,只有一张高铁票的距离~ 所以,湖南郴州,我来了~ 从广州南站出发,一个半小时就到达郴州西站了。在动车上,同时改票的南风兄和我居然被分到了一个车厢,所以一路非常愉快地聊了过来。 挺好,最起…...

    2024/4/28 1:22:35
  18. 氧生福地 玩美北湖(中)——永春梯田里的美与鲜

    原标题:氧生福地 玩美北湖(中)——永春梯田里的美与鲜一觉醒来,因为大家太爱“美”照,在柳毅山庄去寻找龙女而错过了早餐时间。近十点,向导坏坏还是带着饥肠辘辘的我们去吃郴州最富有盛名的“鱼头粉”。说这是“十二分推荐”,到郴州必吃的美食之一。 哇塞!那个味美香甜…...

    2024/4/25 18:39:14
  19. 氧生福地 玩美北湖(下)——奔跑吧骚年!

    原标题:氧生福地 玩美北湖(下)——奔跑吧骚年!让我们红尘做伴 活得潇潇洒洒 策马奔腾共享人世繁华 对酒当歌唱出心中喜悦 轰轰烈烈把握青春年华 让我们红尘做伴 活得潇潇洒洒 策马奔腾共享人世繁华 对酒当歌唱出心中喜悦 轰轰烈烈把握青春年华 啊……啊……啊 两…...

    2024/4/26 23:04:58
  20. 扒开伪装医用面膜,翻六倍价格宰客,小姐姐注意了!

    原标题:扒开伪装医用面膜,翻六倍价格宰客,小姐姐注意了!扒开伪装医用面膜,翻六倍价格宰客!当行业里的某一品项火爆了,就会有很多商家蹭热度,装逼忽悠,最近火爆朋友圈的医用面膜,被沾上了污点,到底怎么回事呢? “比普通面膜安全、效果好!痘痘、痘印、敏感肌都能用…...

    2024/4/27 23:24:42
  21. 「发现」铁皮石斛仙草之神奇功效用于医用面膜

    原标题:「发现」铁皮石斛仙草之神奇功效用于医用面膜丽彦妆铁皮石斛医用面膜|石斛多糖无菌修护补水贴19大优势: 1、铁皮石斛:自唐宋以来,一直被列为皇室贡品,铁皮石斛生于海拔1600米的悬崖峭壁之上,繁殖力差,产量极低,所以古代仅供皇室、贵族享用 2、铁皮石斛自古民间…...

    2024/4/28 5:48:52
  22. 丽彦妆\医用面膜\冷敷贴轻奢医学护肤引导者

    原标题:丽彦妆\医用面膜\冷敷贴轻奢医学护肤引导者【公司简介】 广州华彬企业隶属香港华彬集团有限公司,专注美业21年,其旗下品牌: 「圣茵美」私密荷尔蒙抗衰,产后修复 「圣仪轩」私密荷尔蒙抗衰,产后修复 「花茵莳」私密荷尔蒙抗衰,产后修复 「丽彦妆」专注医学护…...

    2024/4/26 19:46:12
  23. 广州械字号面膜生产厂家OEM/ODM4项须知!

    原标题:广州械字号面膜生产厂家OEM/ODM4项须知!广州械字号面膜生产厂家OEM/ODM流程及注意事项解读: 械字号医用面膜,其实在我国并没有严格的定义,通常我们说的医美面膜指的应该是一种「医用敷料」,也就是说,医用面膜其实算作「医疗器械」的一种,又称「医用冷敷贴」。 …...

    2024/4/27 11:43:08
  24. 械字号医用眼膜缓解用眼过度到底有无作用?

    原标题:械字号医用眼膜缓解用眼过度到底有无作用?医用眼膜/械字号眼膜/医用冷敷眼贴 凝胶层为亲水高分子材料,含70%以上的水分。体表皮肤温度传导到本产品的凝胶层,热量被凝胶内水分子吸收,通过水分的蒸发带走大量的热量,可迅速地降低体表皮肤局部温度,减轻局部皮肤的灼…...

    2024/4/27 8:32:30
  25. 配置失败还原请勿关闭计算机,电脑开机屏幕上面显示,配置失败还原更改 请勿关闭计算机 开不了机 这个问题怎么办...

    解析如下&#xff1a;1、长按电脑电源键直至关机&#xff0c;然后再按一次电源健重启电脑&#xff0c;按F8健进入安全模式2、安全模式下进入Windows系统桌面后&#xff0c;按住“winR”打开运行窗口&#xff0c;输入“services.msc”打开服务设置3、在服务界面&#xff0c;选中…...

    2022/11/19 21:17:18
  26. 错误使用 reshape要执行 RESHAPE,请勿更改元素数目。

    %读入6幅图像&#xff08;每一幅图像的大小是564*564&#xff09; f1 imread(WashingtonDC_Band1_564.tif); subplot(3,2,1),imshow(f1); f2 imread(WashingtonDC_Band2_564.tif); subplot(3,2,2),imshow(f2); f3 imread(WashingtonDC_Band3_564.tif); subplot(3,2,3),imsho…...

    2022/11/19 21:17:16
  27. 配置 已完成 请勿关闭计算机,win7系统关机提示“配置Windows Update已完成30%请勿关闭计算机...

    win7系统关机提示“配置Windows Update已完成30%请勿关闭计算机”问题的解决方法在win7系统关机时如果有升级系统的或者其他需要会直接进入一个 等待界面&#xff0c;在等待界面中我们需要等待操作结束才能关机&#xff0c;虽然这比较麻烦&#xff0c;但是对系统进行配置和升级…...

    2022/11/19 21:17:15
  28. 台式电脑显示配置100%请勿关闭计算机,“准备配置windows 请勿关闭计算机”的解决方法...

    有不少用户在重装Win7系统或更新系统后会遇到“准备配置windows&#xff0c;请勿关闭计算机”的提示&#xff0c;要过很久才能进入系统&#xff0c;有的用户甚至几个小时也无法进入&#xff0c;下面就教大家这个问题的解决方法。第一种方法&#xff1a;我们首先在左下角的“开始…...

    2022/11/19 21:17:14
  29. win7 正在配置 请勿关闭计算机,怎么办Win7开机显示正在配置Windows Update请勿关机...

    置信有很多用户都跟小编一样遇到过这样的问题&#xff0c;电脑时发现开机屏幕显现“正在配置Windows Update&#xff0c;请勿关机”(如下图所示)&#xff0c;而且还需求等大约5分钟才干进入系统。这是怎样回事呢&#xff1f;一切都是正常操作的&#xff0c;为什么开时机呈现“正…...

    2022/11/19 21:17:13
  30. 准备配置windows 请勿关闭计算机 蓝屏,Win7开机总是出现提示“配置Windows请勿关机”...

    Win7系统开机启动时总是出现“配置Windows请勿关机”的提示&#xff0c;没过几秒后电脑自动重启&#xff0c;每次开机都这样无法进入系统&#xff0c;此时碰到这种现象的用户就可以使用以下5种方法解决问题。方法一&#xff1a;开机按下F8&#xff0c;在出现的Windows高级启动选…...

    2022/11/19 21:17:12
  31. 准备windows请勿关闭计算机要多久,windows10系统提示正在准备windows请勿关闭计算机怎么办...

    有不少windows10系统用户反映说碰到这样一个情况&#xff0c;就是电脑提示正在准备windows请勿关闭计算机&#xff0c;碰到这样的问题该怎么解决呢&#xff0c;现在小编就给大家分享一下windows10系统提示正在准备windows请勿关闭计算机的具体第一种方法&#xff1a;1、2、依次…...

    2022/11/19 21:17:11
  32. 配置 已完成 请勿关闭计算机,win7系统关机提示“配置Windows Update已完成30%请勿关闭计算机”的解决方法...

    今天和大家分享一下win7系统重装了Win7旗舰版系统后&#xff0c;每次关机的时候桌面上都会显示一个“配置Windows Update的界面&#xff0c;提示请勿关闭计算机”&#xff0c;每次停留好几分钟才能正常关机&#xff0c;导致什么情况引起的呢&#xff1f;出现配置Windows Update…...

    2022/11/19 21:17:10
  33. 电脑桌面一直是清理请关闭计算机,windows7一直卡在清理 请勿关闭计算机-win7清理请勿关机,win7配置更新35%不动...

    只能是等着&#xff0c;别无他法。说是卡着如果你看硬盘灯应该在读写。如果从 Win 10 无法正常回滚&#xff0c;只能是考虑备份数据后重装系统了。解决来方案一&#xff1a;管理员运行cmd&#xff1a;net stop WuAuServcd %windir%ren SoftwareDistribution SDoldnet start WuA…...

    2022/11/19 21:17:09
  34. 计算机配置更新不起,电脑提示“配置Windows Update请勿关闭计算机”怎么办?

    原标题&#xff1a;电脑提示“配置Windows Update请勿关闭计算机”怎么办&#xff1f;win7系统中在开机与关闭的时候总是显示“配置windows update请勿关闭计算机”相信有不少朋友都曾遇到过一次两次还能忍但经常遇到就叫人感到心烦了遇到这种问题怎么办呢&#xff1f;一般的方…...

    2022/11/19 21:17:08
  35. 计算机正在配置无法关机,关机提示 windows7 正在配置windows 请勿关闭计算机 ,然后等了一晚上也没有关掉。现在电脑无法正常关机...

    关机提示 windows7 正在配置windows 请勿关闭计算机 &#xff0c;然后等了一晚上也没有关掉。现在电脑无法正常关机以下文字资料是由(历史新知网www.lishixinzhi.com)小编为大家搜集整理后发布的内容&#xff0c;让我们赶快一起来看一下吧&#xff01;关机提示 windows7 正在配…...

    2022/11/19 21:17:05
  36. 钉钉提示请勿通过开发者调试模式_钉钉请勿通过开发者调试模式是真的吗好不好用...

    钉钉请勿通过开发者调试模式是真的吗好不好用 更新时间:2020-04-20 22:24:19 浏览次数:729次 区域: 南阳 > 卧龙 列举网提醒您:为保障您的权益,请不要提前支付任何费用! 虚拟位置外设器!!轨迹模拟&虚拟位置外设神器 专业用于:钉钉,外勤365,红圈通,企业微信和…...

    2022/11/19 21:17:05
  37. 配置失败还原请勿关闭计算机怎么办,win7系统出现“配置windows update失败 还原更改 请勿关闭计算机”,长时间没反应,无法进入系统的解决方案...

    前几天班里有位学生电脑(windows 7系统)出问题了&#xff0c;具体表现是开机时一直停留在“配置windows update失败 还原更改 请勿关闭计算机”这个界面&#xff0c;长时间没反应&#xff0c;无法进入系统。这个问题原来帮其他同学也解决过&#xff0c;网上搜了不少资料&#x…...

    2022/11/19 21:17:04
  38. 一个电脑无法关闭计算机你应该怎么办,电脑显示“清理请勿关闭计算机”怎么办?...

    本文为你提供了3个有效解决电脑显示“清理请勿关闭计算机”问题的方法&#xff0c;并在最后教给你1种保护系统安全的好方法&#xff0c;一起来看看&#xff01;电脑出现“清理请勿关闭计算机”在Windows 7(SP1)和Windows Server 2008 R2 SP1中&#xff0c;添加了1个新功能在“磁…...

    2022/11/19 21:17:03
  39. 请勿关闭计算机还原更改要多久,电脑显示:配置windows更新失败,正在还原更改,请勿关闭计算机怎么办...

    许多用户在长期不使用电脑的时候&#xff0c;开启电脑发现电脑显示&#xff1a;配置windows更新失败&#xff0c;正在还原更改&#xff0c;请勿关闭计算机。。.这要怎么办呢&#xff1f;下面小编就带着大家一起看看吧&#xff01;如果能够正常进入系统&#xff0c;建议您暂时移…...

    2022/11/19 21:17:02
  40. 还原更改请勿关闭计算机 要多久,配置windows update失败 还原更改 请勿关闭计算机,电脑开机后一直显示以...

    配置windows update失败 还原更改 请勿关闭计算机&#xff0c;电脑开机后一直显示以以下文字资料是由(历史新知网www.lishixinzhi.com)小编为大家搜集整理后发布的内容&#xff0c;让我们赶快一起来看一下吧&#xff01;配置windows update失败 还原更改 请勿关闭计算机&#x…...

    2022/11/19 21:17:01
  41. 电脑配置中请勿关闭计算机怎么办,准备配置windows请勿关闭计算机一直显示怎么办【图解】...

    不知道大家有没有遇到过这样的一个问题&#xff0c;就是我们的win7系统在关机的时候&#xff0c;总是喜欢显示“准备配置windows&#xff0c;请勿关机”这样的一个页面&#xff0c;没有什么大碍&#xff0c;但是如果一直等着的话就要两个小时甚至更久都关不了机&#xff0c;非常…...

    2022/11/19 21:17:00
  42. 正在准备配置请勿关闭计算机,正在准备配置windows请勿关闭计算机时间长了解决教程...

    当电脑出现正在准备配置windows请勿关闭计算机时&#xff0c;一般是您正对windows进行升级&#xff0c;但是这个要是长时间没有反应&#xff0c;我们不能再傻等下去了。可能是电脑出了别的问题了&#xff0c;来看看教程的说法。正在准备配置windows请勿关闭计算机时间长了方法一…...

    2022/11/19 21:16:59
  43. 配置失败还原请勿关闭计算机,配置Windows Update失败,还原更改请勿关闭计算机...

    我们使用电脑的过程中有时会遇到这种情况&#xff0c;当我们打开电脑之后&#xff0c;发现一直停留在一个界面&#xff1a;“配置Windows Update失败&#xff0c;还原更改请勿关闭计算机”&#xff0c;等了许久还是无法进入系统。如果我们遇到此类问题应该如何解决呢&#xff0…...

    2022/11/19 21:16:58
  44. 如何在iPhone上关闭“请勿打扰”

    Apple’s “Do Not Disturb While Driving” is a potentially lifesaving iPhone feature, but it doesn’t always turn on automatically at the appropriate time. For example, you might be a passenger in a moving car, but your iPhone may think you’re the one dri…...

    2022/11/19 21:16:57