Python高效编程(一)

实际编程和面试都会遇到的典型问题。

图片来源于网络

如何在列表,字典,集合中根据条件筛选数据

from random import randint
from timeit import timeit
​
data = [randint(-10,10) for _ in range(10)]
 
filter(lambda x:x >= 0,data)
#首选列表解析 时间比filter少一半左右
[x for x in data if x >= 0]
​
data = {x:randint(60,100) for x in range(1,21)}
{k:v for k,v in data.items() if v > 90}
​
data = set(data)
{x for x in data if x%3==0}

如何为元组中每个元素命名,提高程序的可读性

#第一种
# NAME = 0
# AGE = 1
# SEX = 2
# EMAIL = 3
NAME,AGE,SEX,EMAIL = range(4)

student = ('Jan',14,'male','jan@jan.net')

#name
print(student[NAME])

#第二种
from collections import namedtuple

Student = namedtuple('Student',['name','age','sex','email'])
student= Student('Jan',14,'male','jan@jan.net')
#name
print(student[NAME])
student.age
isinstance(student,tuple)

如何统计序列中元素的出现频度

from random import randint

data = [randint(1,10) for x in range(20)]
c = dict.fromkeys(data,0)

#第一种
for x in data:
    c[x]+=1
    
#第二种
from collections import Counter

c2 = Counter(data)
#出现频度最高的三个
c2.most_common(3)

#统计一篇文章中单词出现次数
import re
#导入Python之禅
import this

c3 = Counter(re.split('\W+',this.s))

如何根据字典中值的大小,对字典中的项排序

from random import randint

data = {x:randint(60,100) for x in 'abcdefg'}
#sorted(data.values())

#第一种
t = zip(data.values(),data.keys())
sorted(t)

#第二种
sorted(data.items(),key=lambda x: x[1])

如何快速找到多个字典中的公共键(key)

from random import randint,sample

s1 = {x: randint(1,4) for x in sample('abcdefgh',randint(3,6))}
s2 = {x: randint(1,4) for x in sample('abcdefgh',randint(3,6))}
s3 = {x: randint(1,4) for x in sample('abcdefgh',randint(3,6))}

#第一种
res = []
for k in s1:
    if k in s2 and k in s3:
        res.append(k)
        
#第二种
from functools import reduce

s1.keys()&s2.keys()&s3.keys()
map(dict.keys,[s1,s2,s3])
reduce(lambda a, b:a & b,map(dict.keys,[s1,s2,s3]))

如何让字典保持有序

d = {}

d['Tom'] = (1,30)
d['Linda'] = (1,40)
d['Jack'] = (1,50)

from collections import OrderedDict

d = OrderedDict()
d['Tom'] = (1,30)
d['Linda'] = (1,40)
d['Jack'] = (1,50)
d.keys()

from time import time
from random import randint

sorce = OrderedDict()
players = list('abcdefgh')
start = time()

for i in range(8):
    input()
    p = players.pop(randint(0, 7 - i))
    end = time()
    print(i+1,p,end - start)
    sorce[p] = (i+1,end - start)
print('-'*20)

for k in sorce:
    print(k,sorce[k])

如何实现用户的历史记录功能(最多n条)

from collections import deque
from random import randint

N = randint(0,100)
# 一个容纳5个值的队列
history = deque([],5)

def guess(k):
    if k == N:
        print('right!')
        return True
    if k < N:
        print('%s is less than N'%k)
    else:
        print('%s is greater than N'%k)
    return False

while True:
    input_number = input('please input a number: ')
    if input_number.isdigit():
        k = int(input_number)
        history.append(k)
        if guess(k):
            break
    elif input_number == 'history':
        print(list(history))

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏用户2442861的专栏

STL源码剖析-hash_set / hash_multiset

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/haluoluo211/article/d...

931
来自专栏前端黑板报

Javascript即将迎来Optional Chaining

Optional Chaining 现在处于 Stage 1。 它是什么? Optional Chaining 使我们能检查一个对象上面是否存在某属性。其它一些...

3725
来自专栏偏前端工程师的驿站

JS魔法堂:那些困扰你的DOM集合类型

一、前言                                     大家先看看下面的js,猜猜结果会怎样吧!   可选答案:   ①. 获取id属...

2409
来自专栏张善友的专栏

深入浅出事件流处理NEsper(二)

NEsper使用的事件类型来描述事件的类型信息。你的应用在启动时可能预先配置定义事件类型,或者在运行时通过API或EPL语法动态的增加事件类型。 EPL中的cr...

20010
来自专栏LIN_ZONE

javascript基础重点

1.在javascript中使用 == 比较,会自动转换数据类型再比较,有时候会 得到非常诡异的结果;一般情况下使用 === 比较,它不会自动转换数据类型,如果...

952
来自专栏盛国存的专栏

A Bite of GoLang(上)

A bite of GoLang(浅尝GoLang),本文只是Go语言的冰山一角,本文包含作者学习Go语言期间积累的一些小的经验,同时为了方便让读者了解到Go语...

55810
来自专栏华仔的技术笔记

再议Block

3027
来自专栏IMWeb前端团队

20个例子入门Q.js

本文希望通过20个简单的例子让没用过Q.js的同学快速掌握其基本用法 1. 新建实例 html代码: <div id="demo" q-text="msg"><...

2617
来自专栏李蔚蓬的专栏

JavaScript_note1

4.6.字符串运算符 字符串运算符是用于两个字符型数据之间的运算符,除了比较运算符之外,还可以是+和+=运算符。 Demo:

1052
来自专栏水击三千

ARCGIS接口详细说明

ArcGIS接口详细说明 目录 ArcGIS接口详细说明... 1 1.      IField接口(esriGeoDatabase)... 2 2.     ...

4246

扫码关注云+社区

领取腾讯云代金券