[Help] [Newbie] Require help migrating from Perl to Python 2.7 (namespaces)
prilisauer at googlemail.com
prilisauer at googlemail.com
Sat Dec 22 07:45:27 EST 2012
Am Samstag, 22. Dezember 2012 13:38:11 UTC+1 schrieb prili... at googlemail.com:
> Am Samstag, 22. Dezember 2012 12:43:54 UTC+1 schrieb Peter Otten:
>
> > wrote:
>
> >
>
> >
>
> >
>
> > > Hello, to all,
>
> >
>
> > >
>
> >
>
> > > I hope I can describe me problem correctly.
>
> >
>
> > >
>
> >
>
> > > I have written a Project split up to one Main.py and different modules
>
> >
>
> > > which are loaded using import and here is also my problem:
>
> >
>
> > >
>
> >
>
> > > 1. Main.py executes:
>
> >
>
> > > 2. Import modules
>
> >
>
> > > 3. One of the Modules is a SqliteDB datastore.
>
> >
>
> > > 4. A second module creates an IPC socket.
>
> >
>
> > > 5. Here is now my problem :
>
> >
>
> > > The IPC Socket should run a sub which is stored ad SqliteDB and
>
> >
>
> > > returns all Rows.
>
> >
>
> > >
>
> >
>
> > > Is there a elegant way to solve it? except a Queue. Is it possible to
>
> >
>
> > > import modules multiple?!
>
> >
>
> >
>
> >
>
> > If you import a module more than once code on the module level will be
>
> >
>
> > executed the first time only. Subsequent imports will find the ready-to-use
>
> >
>
> > module object in a cache (sys.modules).
>
> >
>
> >
>
> >
>
> > > I'm unsure because the open DB file at another
>
> >
>
> > > module.
>
> >
>
> > >
>
> >
>
> > > How is this solved in bigger projects?
>
> >
>
> >
>
> >
>
> > If I'm understanding you correctly you have code on the module level that
>
> >
>
> > creates a socket or opens a database. Don't do that!
>
> >
>
> > Put the code into functions instead. That will give the flexibility you need
>
> >
>
> > for all sizes of projects. For instance
>
> >
>
> >
>
> >
>
> > socket_stuff.py
>
> >
>
> >
>
> >
>
> > def send_to_socket(rows):
>
> >
>
> > socket = ... # open socket
>
> >
>
> > for row in rows:
>
> >
>
> > # do whatever it takes to serialize the row
>
> >
>
> > socket.close()
>
> >
>
> >
>
> >
>
> > database_stuff.py
>
> >
>
> >
>
> >
>
> > def read_table(dbname, tablename):
>
> >
>
> > if table not in allowed_table_names:
>
> >
>
> > raise ValueError
>
> >
>
> > db = sqlite3.connect(dbname)
>
> >
>
> > cursor = db.cursor()
>
> >
>
> > for row in cursor.execute("select * from %s" % tablename):
>
> >
>
> > yield row
>
> >
>
> > db.close()
>
> >
>
> >
>
> >
>
> >
>
> >
>
> > main.py
>
> >
>
> >
>
> >
>
> > import socket_stuff
>
> >
>
> > import database_stuff
>
> >
>
> >
>
> >
>
> > if __name__ == "__main__":
>
> >
>
> > socket_stuff.send_to_socket(
>
> >
>
> > database_stuff.read_table("some_db", "some_table"))
>
>
>
> Hello Thanks for that answer:
>
> I think I have to write it a bit larger,
>
>
>
> This isn't a real code, but it for better overview:
>
> main.py
>
> / / \ \
>
> -------------------------------------------------------------------
>
> Datastore | ModbusClient | DaliBusClient | Advanced Scheduler
>
> --------------------------------------------------------------------
>
>
>
>
>
> Main.py:
>
> import Datastore
>
> Datastore.startup()
>
> ....
>
> (Everything should run in threads)
>
>
>
> Datastore.py
>
> # Opens a SQLite DB
>
> # Contains Queries to serve data for other mods
>
> # Central point for updating / Quering etc.
>
>
>
> ModbusClient.py
>
> # Opens TCP connection to Modbus Device
>
> !!! Here it's interesting !!!
>
> This module contains predefined Queries and functions
>
> IF I START A FUNCTION a SQL should be executed in Datastore.py
>
>
>
>
>
> DaliBusClient.py
>
> #Lamps, etc. Functions.
>
> # Stored Informations should be kept in Datastore
>
> # Advanced scheduler
>
>
>
>
>
> I don't know, Python allways looks for me like a one script "File". But there are big projects. like the the "Model of an SQL Server", using coordinators no problems running threads and exchange Data through a Backbone. I have searched a lot, but I havent find anything to write the "core" splited up into modules and geting over the scopes etc.
>
>
>
> DO I have anything forgotten?! everything unclear?? :-P
Ps.: The Socket, the DB has to be kept allways open, because of it's Server functionality, A lot of Sensors, Timers, User interaction, must recived , Calculated, etc so a reaction must be send in about 16~100 ms, different modules opens and closes Sockets or files, could result in a dead situation.
Or do i didn't see any Tree's in the Wood?
Br
More information about the Python-list
mailing list