Liste des Groupes | Revenir à cl c |
On Mon, 17 Jun 2024 15:23:55 +0200"Faffing around" or "faffing about" means messing around doing unimportant or unnecessary things instead of useful things. In this case, it means writing lots of code for handling memory management to read a file instead of using a higher-level language and just reading the file.
David Brown <david.brown@hesbynett.no> wrote:
I use Python rather than C because forThe faffing (what does it mean, BTW ?) is caused by unrealistic
PC code, that can often involve files, text manipulation, networking,
and various data structures, the Python code is at least an order of
magnitude shorter and faster to write. When I see the amount of
faffing around in order to read and parse a file consisting of a list
of integers, I find it amazing that anyone would actively choose C
for the task (unless it is for the fun of it).
>
requirements. More specifically, by requirements of (A) to support
arbitrary line length (B) to process file line by line. Drop just one
of those requirements and everything become quite simple.
For task like that Python could indeed be several times shorter, butNo, even if that were part of the specifications, it would still be far easier in Python. The brief Python samples I have posted don't cover such user help, options, error checking, etc., but that's because they are brief samples.
only if you wrote your python script exclusively for yourself, cutting
all corners, like not providing short help for user, not testing that
input format matches expectations and most importantly not reporting
input format problems in potentially useful manner.
OTOH, if we write our utility in more "anal" manner, as we should ifUnless half the code is a text string for a help page, I'd expect a bigger factor. And I'd expect the development time difference to be an even bigger factor - with Python you avoid a number of issues that are easy to get wrong in C (such as memory management). Of course that would require a reasonable familiarity of both languages for a fair comparison.
we expect it to be used by other people or by ourselves long time after
it was written (in my age, couple of months is long enough and I am not
that much older than you) then code size difference between python and
C variants will be much smaller, probably factor of 2 or so.
W.r.t. faster to code, it very strongly depends on familiarity.Sure - familiarity with a particular tool is a big reason for choosing it.
You didn't do that sort of tasks in 'C' since your school days, right?
Or ever? And you are doing them in Python quite regularly? Then that is
much bigger reason for the difference than the language itself.
Now, for more complicated tasks Python, as the language, and even moreIMHO, it does. I have slightly lost track of which programs were being discussed in which thread, but the Python code for the task is a small fraction of the size of the C code. I agree that if you want to add help messages and nicer error messages, the difference will go down.
importantly, Python as a massive set of useful libraries could have
very big productivity advantage over 'C'. But it does not apply to very
simple thing like reading numbers from text file.
In the real world, I wrote utility akin to that less than two years ago.Of course if you don't know Python, it will be slower to write it in Python!
It converted big matrices from space delimited text to Matlab v4 .mat
format. Why did I do it? Because while both Matlab and Gnu Octave are
capable of reading text files like those, but they are quite slow doing
so. With huge files that I was using at the moment, it became
uncomfortable.
I wrote it in 'C' (or was it C-style C++ ? I don't remember) mostly
because I knew how to produce v4 .mat files in C. If I were doing it in
Python, I'd have to learn how to do it in Python and at the end it
would have taken me more time rather than less. I didn't even came to
the point of evaluating whether speed of python's functions for parsing
text was sufficient for my needs.
Les messages affichés proviennent d'usenet.