Νίκος wrote:
On 8 Αύγ, 17:59, Thomas Jollans <tho...@jollans.com> wrote:

Two problems here:

str.replace doesn't use regular expressions. You'll have to use the re
module to use regexps. (the re.sub function to be precise)

'.'  matches a single character. Any character, but only one.
'.*' matches as many characters as possible. This is not what you want,
since it will match everything between the *first* <? and the *last* ?>.
You want non-greedy matching.

'.*?' is the same thing, without the greed.

Thanks you,

So i guess this needs to be written as:

src_data = re.sub( '<?(.*?)?>', '', src_data )

In a regex '?' is a special character, so if you want a literal '?' you
need to escape it. Therefore:

    src_data = re.sub(r'<\?(.*?)\?>', '', src_data)

Tha 'r' special char doesn't need to be inserter before the regex here
due to regex ain't containing backslashes.

You will have to find the </body> tag before inserting the string.
str.find should help -- or you could use str.replace and replace the
</body> tag with you counter line, plus a new </body>.

Ah yes! Damn why din't i think of it.... str.replace should do the
trick. I was stuck trying to figure regexes.

So, i guess that should work:

 src_data = src_data.replace('</body>', '<br><br><h4><font
color=green> Αριθμός Επισκεπτών: %(counter)d </font></h4></body>' )

No it's not. You're just giving up too soon.

Yes youa re right, your hints keep me going and thank you for that.

--
http://mail.python.org/mailman/listinfo/python-list

Reply via email to