我已经构建了一个套接字服务器,用于侦听来自另一台客户机的命令(我无法访问的代码).客户端发送与键击相关的号码,并发送与修改键按下相关的修饰符代码.所以举个例子
shift=1
control=2
alt=4
win=8
Run Code Online (Sandbox Code Playgroud)
发送的修饰符代码始终是一个数字.例如,修饰符= 1.但是如果发送的密钥超过1个,则可以说modifier = 3(即shift + control).问题是我如何计算密钥的数量.
所以为了简单起见,我们使用a,b,c,d-规则只是组合中的一个.
因此,如果:
a=1
b=2
c=4
d=8
Run Code Online (Sandbox Code Playgroud)
然后这些是组合的总数:
a+b=> 3
a+c=> 5
a+d=> 9
b+d=> 10
c+b=> 6
c+d=> 12
a+b+c=> 7
a+b+d=> 11
a+b+c+d=> 15
Run Code Online (Sandbox Code Playgroud)
那么在Python中计算n的最佳方法是什么?开关?
switch(n):
case 3:
print 'its a+b'
case 5:
print 'its a+c'
Run Code Online (Sandbox Code Playgroud)
...等等..
一定有更好的方法吗?
您可以使用按位运算的强大功能:
def switches(n, num=4):
return [n & (2**i) > 0 for i in range(num)]
Run Code Online (Sandbox Code Playgroud)
这将返回一个列表,其中每个项都是一个布尔值,表示是否按下了该开关:
>>> switches(10)
[False, True, False, True]
# a b c d
Run Code Online (Sandbox Code Playgroud)
这就是为什么组件都是2的幂 - 当你将总数视为二进制数(注意颠倒顺序)时,它使访问每个开关的值变得微不足道:
>>> format(10, 'b') # show 10 as a binary number
'1010'
#8421
#dcba
Run Code Online (Sandbox Code Playgroud)
要显示所有选项:
>>> for i in range(2**4):
print(i, '\t', format(i, '04b'))
0 0000 # no switches
1 0001 # a only
2 0010
3 0011
4 0100
5 0101
6 0110
7 0111 # a, b and c
8 1000
9 1001
10 1010 # b and d
11 1011
12 1100
13 1101
14 1110
15 1111 # all switches
Run Code Online (Sandbox Code Playgroud)