Python's Suitability?

Nick Craig-Wood nick at craig-wood.com
Tue Aug 28 07:30:07 EDT 2007


Michael R. Copeland <mrc2323 at cox.net> wrote:
>     I have some questions about the suitability of Python for some 
>  applications I've developed in C/C++.  These are 32 bit Console 
>  applications, but they make extensive use of STL structures and 
>  functions (Lists, Maps, Vectors, arrays) - primarily because the data 
>  volume is high (2,500,000+ records).

This is all bread and butter stuff to python and 10 times easier to do
in python than C++!

>     The main thing I'd like to do is port one part of the system that has 
>  a series of user menus and works with several text data files (one 
>  _very_ large).  I'm not using any database system, just my home-grown 
>  indexed sequential file database.  There's nothing but volume that 
>  precludes this application from running from almost any text file-
>  processing language system (e.g. Perl, BASIC, etc.).
>     From what little I've seen of Python, it appears I could port this 
>  application to Python code, but I'd do so only if I could:
>    1. Integrate it into a Web application in such a way that the user 
>  could select it as an option from a main page and have it execute as a 
>  WEB GUI application.  Currently, the application's interface is only a 
>  crude DOS window.

A web application is possible.  You can start your application which
would run its own embedded web server which the user could then
control.  Python has a web server in the standard library.  I've done
exactly this using cherrypy as a simple web application framework.

The asynchronous nature of web applications are often a pain.  You
could write a windows GUI using TKinter (which comes with python) or
WxPython (which doesn't).  Those toolkits make it very easy to make
GUI applications.

>    2. Assure that the performance isn't totally crippled by using Python, 
>  an interpretted language.  While I don't expect native C/C++ 
>  performance, I don't want to be embarrassed...

Depends exactly what you are doing.  If you are IO limited then Python
is just as fast as C++.

If you are doing lots of calculation on the data then python can be
slow.  You can use the numpy library which is a library of scientific
maths routines all coded in C for speed which is very quick.

  http://numpy.scipy.org
  http://sourceforge.net/projects/numpy

>    3. Make sure that the volume of stored data (2.5+ million records) can 
>  be accommodated in Python structures (I don't know enough about Python 
>  to answer this question...).

I wouldn't have thought that would be a problem.

>     Note that I'm not considering using the existing C/C++ code in my Web 
>  application, because I don't know how to write a C/C++ Windows 
>  application - and I'm sure the learning curve here is greater than 
>  Python's.

You could always use ctypes from python to interface with your C
code.  If you can export your code in a DLL then ctypes can use it.
(Not sure about C++ though)

> I'm a very old procedural-based application developer (47+ 
>  years of programming experience), and developing Windows applications is 
>  beyond me.
>     So, I only (?) want to take an existing application that uses a large 
>  text file (and several smaller text indexing files) and put it into a 
>  Web system I already have.  I feel Python (or Perl) is(are) my best 
>  option(s), and here I'm only looking for some initial guidance from the 
>  Python users.  TIA

Go for it!  Python is such an easy language to write stuff in
(escpecially compared to C++) that you'll have the prototype done very
quickly and you can evaluate the rest of your concerns with working
code!

-- 
Nick Craig-Wood <nick at craig-wood.com> -- http://www.craig-wood.com/nick



More information about the Python-list mailing list