关于数据可视化:体系课数据可视化入门到精通打造前端差异化竞争力已完结fafa

31次阅读

共计 2126 个字符,预计需要花费 6 分钟才能阅读完成。

download: 体系课 - 数据可视化入门到精通 - 打造前端差异化竞争力(已完结)

构造字符串

你会常常需要打印字符串。要是有很多变量,避免上面这样:

name = “Raymond”
age = 22
born_in = “Oakland, CA”
string = “Hello my name is ” + name + “and I’m ” + str(age) + ” years old. I was born in ” + born_in + “.”
print(string)
额,这看起来多乱呀?你可能用个丑陋简洁的方法来代替,.format。

这样做:

name = “Raymond”
age = 22
born_in = “Oakland, CA”
string = “Hello my name is {0} and I’m {1} years old. I was born in {2}.”.format(name, age, born_in)
print(string)
返回 tuple 元组

Python 容许你在一个函数中返回多个元素,这让生存更简略。然而在解包元组的时候出出线这样的常见谬误:

def binary(): return 0, 1
result = binary()
zero = result[0]
one = result[1]
这是没必要的,你残缺可能换成这样:

def binary(): return 0, 1
zero, one = binary()
要是你需要所有的元素被返回,用个下划线 _:

zero, _ = binary()
就是这么高效率!

拜访 Dict 字典

你也会常常给 dicts 中写入 key,value(键,值)。

如果你试图拜访一个不存在的于 dict 的 key,可能会为了避免 KeyError 谬误,你会偏向于这样做:

countr = {}
bag = [2, 3, 1, 2, 5, 6, 7, 9, 2, 7]
for i in bag:
if i in countr:
countr[i] += 1 else:
countr[i] = 1
for i in range(10):
if i in countr:
print(“Count of {}: {}”.format(i, countr[i]))
else:
print(“Count of {}: {}”.format(i, 0))
然而,用 get() 是个更好的办法。

countr = {}
bag = [2, 3, 1, 2, 5, 6, 7, 9, 2, 7]
for i in bag:
countr[i] = countr.get(i, 0) + 1
for i in range(10):
print(“Count of {}: {}”.format(i, countr.get(i, 0)))
当然你也可能用 setdefault 来代替。

这还用一个更简略却多费点开销的办法:

bag = [2, 3, 1, 2, 5, 6, 7, 9, 2, 7]

{2: 3, 3: 1, 1: 1, 5: 1, 6: 1, 7: 2, 9: 1}

countr = dict([(num, bag.count(num)) for num in bag])
for i in range(10):
print(“Count of {}: {}”.format(i, countr.get(i, 0)))
你也可能用 dict 推导式。

countr = {num: bag.count(num) for num in bag}
这两种方法开销大是因为它们在每次 count 被调用时都会对列表遍历。

使用库

现有的库只需导入你就可能做你真正想做的了。

还是说后面的例子,咱们建一个函数来数一个数字在列表中出现的次数。那么,已经有一个库就可能做这样的事件。

from collections import Counter
bag = [2, 3, 1, 2, 5, 6, 7, 9, 2, 7]
countr = Counter(bag)for i in range(10):
print(“Count of {}: {}”.format(i, countr[i]))
一些用库的理由:

代码是正确而且通过测试的。
它们的算法可能会是最优的,这样就跑的更快。
抽象化:它们指向明确而且文档敌对,你可能专一于那些还没有被实现的。
最初,它都已经在那儿了,你不必再造轮子了。
在列表中切片 / 步进
你可能指定 start 的点和 stop 点,就像这样 list[start:stop:step]。咱们取出列表中的前 5 个元素:

bag = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9]
for elem in bag[:5]:
print(elem)
这就是切片,咱们指定 stop 点是 5,再停止前就会从列表中取出 5 个元素。

要是最初 5 个元素怎么做?

bag = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9]
for elem in bag[-5:]:
print(elem)
没看明确吗?-5 意味着从列表的结尾取出 5 个元素。

如果你想对列表中元素间隔操作,你可能会这样做:

bag = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9]
for index, elem in enumerate(bag):
if index % 2 == 0:
print(elem)
然而你应该这样来做:

bag = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9]
for elem in bag[::2]:
print(elem)

或者用 ranges

bag = list(range(0,10,2))
print(bag)
这就是列表中的步进。list[::2] 意义是遍历列表同时两步取出一个元素。

你可能用 list[::-1] 很酷的翻转列表。

正文完
 0