<div class="gmail_quote">On 3 September 2012 15:12, Mark R Rivet <span dir="ltr"><<a href="mailto:markrrivet@aol.com" target="_blank">markrrivet@aol.com</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
Hello all, I am learning to program in python. I have a need to make a<br>
program that can store, retrieve, add, and delete client data such as<br>
name, address, social, telephone number and similar information. This<br>
would be a small client database for my wife who has a home accounting<br>
business.<br></blockquote><div><br></div><div>I would use the sqlite3 module for this (if I wasn't using gmail contacts).</div><div> </div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
I have been reading about lists, tuples, and dictionary data<br>
structures in python and I am confused as to which would be more<br>
appropriate for a simple database.<br></blockquote><div><br></div><div>As already said by Chris these are the types that Python uses to represent data in memory, rather than on disk. There are a number of ways that you can use these to represent the information from your database. For example, you could use a dict of dicts:</div>
<div><br></div><div><div>>>> contact_db = {} # empty dict</div><div>>>> contact_db['john'] = {'alias':'john', 'name':'John Doe', 'email': '<a href="mailto:john@example.com" target="_blank">john@example.com</a>'}</div>
<div>>>> contact_db['dave'] = {'alias':'dave', 'name':'Dave Doe', 'email': '<a href="mailto:dave@example.com" target="_blank">dave@example.com</a>'}</div><div>
>>> contact_db</div>
<div>{'dave': {'alias': 'dave', 'name': 'Dave Doe', 'email': '<a href="mailto:dave@example.com" target="_blank">dave@example.com</a>'}, 'john': {'alias': 'john', 'name': 'John Doe', 'email': '<a href="mailto:john@example.com" target="_blank">john@example.com</a>'}}</div>
<div>>>> contact_db['dave']</div><div>{'alias': 'dave', 'name': 'Dave Doe', 'email': '<a href="mailto:dave@example.com" target="_blank">dave@example.com</a>'}</div>
<div>>>> contact_db['dave']['email']</div>
<div>'<a href="mailto:dave@example.com" target="_blank">dave@example.com</a>'</div></div><div><br></div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
I know that python has real database capabilities but I'm not there<br>
yet and would like to proceed with as simple a structure as possible.<br></blockquote><div><br></div><div>If you don't want to use real database capabilities you could save the data above into a csv file using the csv module:</div>
<div><br></div><div><div>>>> import csv</div><div>>>> with open('contacts.csv', 'wb') as f:</div><div>... writer = csv.DictWriter(f)</div><div>... writer.writelines(contact_db.values())</div>
</div><div><br></div><div>You can then reload the data with:</div><div><br></div><div><div>>>> with open('contacts.csv', 'rb') as f:</div><div>... reader = csv.DictReader(f, ['alias', 'name', 'email'])</div>
<div>... new_contact_db = {}</div><div>... for row in reader:</div><div>... new_contact_db[row['alias']] = row</div><div>...</div><div>>>> new_contact_db</div><div>{'dave': {'alias': 'dave', 'name': 'Dave Doe', 'email': '<a href="mailto:dave@example.com" target="_blank">dave@example.com</a>'}, 'john': {'alias': 'john', 'name': 'John Doe', 'email': '<a href="mailto:john@example.com" target="_blank">john@example.com</a>'}}</div>
<div>>>> contact_db == new_contact_db</div><div>True</div></div><div> </div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
<br>
Can anyone give me some idea's or tell me which structure would be<br>
best to use?<br></blockquote><div><br></div><div>The above method for storing the data on disk is simple but not very safe. If you use it for your wife's business make sure that you are always keeping backups of the file. Preferably don't overwrite the file directly but write the data out to a separate file first and then rename the file (to avoid loss of data if the program has an error while writing).</div>
<div><br></div><div>The obvious way to improve on the above is to use the sqlite3 module to store the data in an sqlite3 file instead of a csv file. There is one advantage to using the above over using an sqlite3 database which is that the data can be edited manually as a text file or using standard spreadsheet software if necessary.</div>
<div><br></div><div>Oscar</div></div>