Path: csiph.com!v102.xanadu-bbs.net!xanadu-bbs.net!feeder.erje.net!eu.feeder.erje.net!xlned.com!feeder3.xlned.com!news2.euro.net!newsgate.cistron.nl!newsgate.news.xs4all.nl!post.news.xs4all.nl!not-for-mail Return-Path: X-Original-To: python-list@python.org Delivered-To: python-list@mail.python.org X-Spam-Status: OK 0.016 X-Spam-Evidence: '*H*': 0.97; '*S*': 0.00; 'subject:Why': 0.09; 'suggestions:': 0.09; 'cc:addr:python-list': 0.11; '(use': 0.16; 'from:addr:pobox.com': 0.16; 'from:addr:skip': 0.16; 'subject:slow': 0.16; 'sender:addr:gmail.com': 0.17; 'split': 0.19; 'seems': 0.21; 'cc:addr:python.org': 0.22; 'creating': 0.23; 'skip': 0.24; 'cc:2**0': 0.24; 'cc:no real name:2**0': 0.24; 'header:In-Reply-To:1': 0.27; 'matching': 0.30; 'message- id:@mail.gmail.com': 0.30; 'beginning': 0.33; 'could': 0.34; 'but': 0.35; 'received:google.com': 0.35; 'subject:?': 0.36; 'easily': 0.37; 'does': 0.39; 'first': 0.61; 'obvious': 0.74; 'yourself': 0.78 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20120113; h=mime-version:sender:in-reply-to:references:date :x-google-sender-auth:message-id:subject:from:to:cc:content-type; bh=RuMEVYNj6rMQoFJIFuEs0MxuC7fuQesSPI3UiPf0URQ=; b=EXiTUP/ngYqcvM5NKXQN4RsWOM0ccKtRbILg6A0M/a4A8h2jbSWdUP16Kyg4MkL/kX M5xlrKopY9vqt6scmhmLE/18gSoSq0aqAMQyr37kdzqSFYRhZzT1S0uz3Gx9vb8SRzL4 gk9sI1NJG2r8ygG8896kQTIvgxyBcYBTV/89Yr4Hukko29Ldw14SaOC2UTDO7GzS/aGo 2uZxDWrGoypsBm+GiZHvDMClifB/ECHgf8KPf+N3Bk1LCrjoHyz5O4iWn1yQ/T0J8T92 CgMABqEZPeTmBDBLHTgv/HmIHVRwM6U5m4DpoHkTL/Egj8qx7jf8RnoEVW8/VfS4rIYY zokQ== MIME-Version: 1.0 X-Received: by 10.50.9.7 with SMTP id v7mr8181687iga.51.1371574886454; Tue, 18 Jun 2013 10:01:26 -0700 (PDT) Sender: skip.montanaro@gmail.com In-Reply-To: References: Date: Tue, 18 Jun 2013 12:01:26 -0500 X-Google-Sender-Auth: M6iF1LWpKOv31KwZkVB9bZ9fjjo Subject: Re: Why is regex so slow? From: Skip Montanaro To: Roy Smith Content-Type: text/plain; charset=UTF-8 Cc: python-list@python.org X-BeenThere: python-list@python.org X-Mailman-Version: 2.1.15 Precedence: list List-Id: General discussion list for the Python programming language List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Newsgroups: comp.lang.python Message-ID: Lines: 12 NNTP-Posting-Host: 2001:888:2000:d::a6 X-Trace: 1371574888 news.xs4all.nl 15917 [2001:888:2000:d::a6]:57758 X-Complaints-To: abuse@xs4all.nl Xref: csiph.com comp.lang.python:48643 > I don't understand why the first way is so much slower. I have no obvious answers, but a couple suggestions: 1. Can you anchor the pattern at the beginning of the line? (use match() instead of search()) 2. Does it get faster it you eliminate the "(.*)" part of the pattern? It seems that if you find a line matching the first part of the pattern, you could just as easily split the line yourself instead of creating a group. Skip