参考How to list all files of a directory?
有时候在打开文件的时候,不知道文件的编码。这个时候就需要先探测到文件的编码,然后再以探测到的文件编码打开。但是在Python中并没有相关的包可以用来获取文件的编码,可以借助于第三方的库chardet
更新pip3
pip3 install --upgrade pip更新pip2
pip2 install --upgrade pip很多时候需要使用Python得到所有字符,包括特殊字符。
import string string.printable最后的结果为
0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ!"#$%&\'()*+,-./:;?@[\\]^_`{|}~ \t\n\r\x0b\x0c有时候需要生成等长的数字序列,如001,002一直到100 使用常规的range只能生成普通的1,2,3这样的字符串。 可以使用zfill()函数来完成
num = [str(i) for i in range(100)] new_nums = [] for i in num: i = i.zfill(3) new_nums.append(i) print(new_nums)其中的zfill(3)就是表示需要生成三位数的数字 最后的结果就是:
不知道如何翻译成为中文,但是看代码示例就应该知道了。
可以看到list2d是一个二级list,如果出现3级list,那么上述的方法就会失败。
import itertools list2d = [[1, 2, 3,[11,12,13]],[4,5,6,[14,15,16]]] merged = list(itertools.chain.from_iterable(list2d)) print(merged) #output:[1, 2, 3, [11, 12, 13], 4, 5, 6, [14, 15, 16]]说明使用itertools.chain.from_iterable只能解压两层
面对不同形式的list,最好的方式是使用递归来解决。
def flatten(x): import collections if isinstance(x, collections.Iterable): return [a for i in x for a in flatten(i)] else: return [x] def get_flattern_List(): list2d = [[1, 2, 3], [4, 5, 6], [7], [8, 9, [10, 11,[12,13]]]] result = flatten(list2d) print(result) #output:[1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13]使用递归的方式,可以解决不规则的list的问题。
转载于:https://www.cnblogs.com/babers/p/6746162.html
相关资源:第3章 Python常用语句.pptx