在python中将函数链接为shell管道命令

时间:2011-06-04 05:56:32

标签: python function shell pipe

在Unix / linux shell中我们可以:

seq 0 100 | head -10 | awk 'NF%2==0' | awk 'NF%2==1' | rev

现在我定义了:

seqsrc = list(range(0,100))

def all(src): return src
def head(src, count, offset = 0): return src[:count]
def tail(src, count, offset = 0): return src[-count:]
def odd(src): return [x for x in src if x % 2 != 0]
def even(src): return [x for x in src if x % 2 == 0]
def reverse(src): return src[::1]
...
#def other_sequence_manpulation_method()

以下是我的问题:

1。 如何在python中获得类似语法的shell管道?

seqdst = all(seqsrc).head(10).odd().even().reverse()

2。 出于某种原因,我想列举我定义的那些简单函数的所有可能组合,我可以用itertools.product()来生成组合 - 编辑:以及下面的Seq类解决方案吗?

possible_head_limit = [10,20,30]

all(seqsrc).head(10)                    # 10 is one item in possible_head_limit
all(seqsrc).head(10).odd()
all(seqsrc).head(10).odd().even()
all(seqsrc).head(10).odd().even().reverse()
all(seqsrc).head(10).even()
all(seqsrc).head(10).even().odd()
....
all(seqsrc).head(20)                    # 20 is one item in possible_head_limit

all(seqsrc).head(20).odd()
...

3: 假设seqsrc = range(0,10)然后head(20)可能会返回与head(10)相同或有时无意义

all(seqsrc).head(20).odd().even().reverse()  
# = all(seqsrc).head(10).odd().even().reverse() 
# = all(seqsrc).head(11).odd().even().reverse()
# ...

我可以在方法链中添加控制功能,然后我可以控制返回的平均值吗?

ignore_insufficient(True).all(seqsrc).head(20).odd().even().reverse()
ignore_insufficient(False).all(seqsrc).head(20).odd().even().reverse()  # it will print some sort of error

# or even I can control each function I defined?
ignore_insufficient(True).all(seqsrc).\
ignore_insufficient(True).head(20).\
ignore_insufficient(False).tail(10)

谢谢!

1 个答案:

答案 0 :(得分:4)

你的帖子中有很多问题,我不确定是否都能理解这些问题。但是,这是一个起点。

可链接方法通常通过使用返回类本身的新实例的方法设计类来实现。这允许从先前方法的返回值调用其他方法。

因此,您可以按如下方式定义Seq类:

class Seq(object):
    def __init__(self, seq):
        self.seq = seq
    def __repr__(self):
        return repr(self.seq)
    def __str__(self):
        return str(self.seq)
    def all(self):
        return Seq(self.seq[:])
    def head(self, count):
        return Seq(self.seq[:count])
    def tail(self, count):
        return Seq(self.seq[-count:])
    def odd(self):
        return Seq(self.seq[1::2])
    def even(self):
        return Seq(self.seq[::2])
    def reverse(self):
        return Seq(self.seq[::-1])

并使用它:

>>> s = Seq(range(0, 100))
>>> print s.head(10).odd().even().reverse()
[9, 5, 1]

请注意,这可以通过多种方式进行改进。例如,在Javascript世界中,jQuery的可链接方法实际上将其结果推送到堆栈中,从而允许在调用历史记录中恢复回溯并恢复先前的上下文。有关详细信息,请参阅end()