473,405 Members | 2,287 Online
Bytes | Software Development & Data Engineering Community
Post Job

Home Posts Topics Members FAQ

Join Bytes to post your question to a community of 473,405 software developers and data experts.

I/O Error

Hi,
I am using File I/O to input an xml file form user and parse it.I
have used something like this:
file_input = raw_input("Enter The ODX File Path:")
odx_file_output = raw_input("Enter the output file path : ")
log_file_output = raw_input("Enter the path for LogFile : ")

saveout = sys.stdout
try:
f_open=open(odx_file_output, 'w')
except:
print "cant open file"
sys.exit()
sys.stdout = f_open

try:
input_xml = open(file_input,'r')
except:
print "The File Cannot Be Opened"
sys.exit()

if input_xml.read(5)!='<?xml':
print "Invalid File"
input_xml.close()
sys.exit()
else:
xmldoc = minidom.parse(input_xml)
input_xml.close()

if xmldoc.childNodes[1].getAttribute("DtdVers") == u'1.1.4' or
xmldoc.childNodes[1].getAttribute("DtdVers")== u'1.1.5':
pass
else:
print "Invalid Version"
sys.exit()

After this some more code follows,but i have
pasted only the i/o part .when i run it in interactive mode(using
F5),first time it does fine,but second time it throws error like:

Traceback (most recent call last):
File "C:\Projects\ODX Import\code_ini\odxparse.py", line 250, in
<module>
file_input = raw_input("Enter The ODX File Path:")
ValueError: I/O operation on closed file

any idea what should be modified.
Thx

Apr 24 '07 #1
1 2914
sa**********@gmail.com wrote:
file_input = raw_input("Enter The ODX File Path:")
odx_file_output = raw_input("Enter the output file path : ")
log_file_output = raw_input("Enter the path for LogFile : ")

saveout = sys.stdout
try:
f_open=open(odx_file_output, 'w')
except:
print "cant open file"
sys.exit()
sys.stdout = f_open

try:
input_xml = open(file_input,'r')
except:
print "The File Cannot Be Opened"
sys.exit()

if input_xml.read(5)!='<?xml':
print "Invalid File"
input_xml.close()
sys.exit()
else:
xmldoc = minidom.parse(input_xml)
input_xml.close()

if xmldoc.childNodes[1].getAttribute("DtdVers") == u'1.1.4' or
xmldoc.childNodes[1].getAttribute("DtdVers")== u'1.1.5':
pass
else:
print "Invalid Version"
sys.exit()

After this some more code follows,but i have
pasted only the i/o part .
In the future, it is best to be able to produce a short and complete
test case. Doing so may help you find your error, without assistance.
Traceback (most recent call last):
File "C:\Projects\ODX Import\code_ini\odxparse.py", line 250, in
<module>
file_input = raw_input("Enter The ODX File Path:")
ValueError: I/O operation on closed file
Well, you set sys.stdout to f_open, and you probably closed it without
setting it back. Can't tell because you didn't include the whole script
(and you shouldn't do that either--make a test case).

Here are some general comments:

1) Redirecting sys.stdout does not seem advisable in this case, and
seems to be causing some confusion. It's far better to make a new file
handle for your output. You can print to it using:

print >>filehandle, "message"

2) Interactively asking for filenames like this will cause irritation
for yourself, and possibly your users if they ever want to automate
things. My personal preference would be to accept the arguments on the
command line. If your users don't know how to use a command line, then
you should really be getting the filenames through some sort of GUI
instead of raw_input().

3) I try to name my file-related variables consistently so I know where
they are. Naming the file name variable and the file handle variable
something completely different is confusing.

4) If you have some abnormal exit condition, you should exit with
sys.exit(1) or really any number besides 0. Exiting with sys.exit() or
sys.exit(0) means everything is fine.

5) If an exception occurs that will result in the end of the program,
there's no point in catching it just to print a less descriptive error
message and quit. It makes your code harder to understand with all the
exception catching, and it makes it harder to debug because you lose
crucial details of where the exception occurred and what its calling
stack was.

6) Further, I'm not sure how much sense it makes to double-check that
the file begins with "<?xml". minidom.parse will check that just fine.
And it will catch all sorts of other errors as well, and you can't do
them all yourself at this point.

Here's how I would rewrite it using Python 2.5:

from __future__ import with_statement

import sys
from xml.dom import minidom

ACCEPTABLE_DTD_VERSIONS = [u'1.1.4', u'1.1.5']

class DTDVersionError(StandardError):
pass

def io(infilename, outfilename, logfilename):
with open(outfilename, "w") as outfile:
with open(infilename) as infile:
xmldoc = minidom.parse(input_xml)

dtd_version = xmldoc.childNodes[1].getAttribute("DtdVers")
if dtd_version not in ACCEPTABLE_DTD_VERSIONS:
raise DTDVersionError(infilename)

def main(args):
return io(*args)

if __name__ == "__main__":
sys.exit(main(sys.argv[1:]))

As far as the interface goes, you can run this from the commandline as
example.py INFILE OUTFILE LOGFILE. Or from IDLE as io("INFILE",
"OUTFILE", "LOGFILE"). That way you can re-run it many times without
having to retype three file names each time, yuck. If you want to add a
GUI for other users to select files, you can call it from main() if
there are no command-line arguments, keeping the bulk of your logic in
io() separate from the interface.

Let us know if you have any questions about what I have done here.
--
Michael Hoffman
Apr 24 '07 #2

This thread has been closed and replies have been disabled. Please start a new discussion.

Similar topics

2
by: AIM | last post by:
Error in msvc in building inheritance.obj to build hello.pyd Hello, I am trying to build the boost 1.31.0 sample extension hello.cpp. I can not compile the file inheritance.cpp because the two...
2
by: Gregory | last post by:
Hi, One of the disadvantages of using error handling with error codes instead of exception handling is that error codes retuned from a function can be forgotten to check thus leading to...
13
by: deko | last post by:
I use this convention frequently: Exit_Here: Exit Sub HandleErr: Select Case Err.Number Case 3163 Resume Next Case 3376 Resume Next
7
by: p | last post by:
WE had a Crystal 8 WebApp using vs 2002 which we upgraded to VS2003. I also have Crystal 9 pro on my development machine. The web app runs fine on my dev machine but am having problems deploying....
3
by: Manuel | last post by:
I'm trying to compile glut 3.7.6 (dowbloaded from official site)using devc++. So I've imported the glut32.dsp into devc++, included manually some headers, and start to compile. It return a very...
0
by: bazzer | last post by:
hey, im trying to access a microsoft access database from an ASP.NET web application in visual basic 2003.NET. i get the following error when i try running it: Server Error in...
1
by: developer | last post by:
Hi All I have made a .NET project. the files included are borland c++ files that i am migrate to VC++ .NET I am using Microsoft Visual C++ .NET 2003. the compilation goes through properly,...
0
by: mchuc7719 | last post by:
Hello, I have a Vb.Net 2005 ClassLibrary, when I try to compile using MSBee, only get errors. Before I to run the command line, I open in notepad the .vbproj and I was add the next line: ...
2
hyperpau
by: hyperpau | last post by:
Before anything else, I am not a very technical expert when it comes to VBA coding. I learned most of what I know by the excellent Access/VBA forum from bytes.com (formerly thescripts.com). Ergo, I...
0
hyperpau
by: hyperpau | last post by:
Before anything else, I am not a very technical expert when it comes to VBA coding. I learned most of what I know by the excellent Access/VBA forum from bytes.com (formerly thescripts.com). Ergo, I...
0
by: Charles Arthur | last post by:
How do i turn on java script on a villaon, callus and itel keypad mobile phone
0
BarryA
by: BarryA | last post by:
What are the essential steps and strategies outlined in the Data Structures and Algorithms (DSA) roadmap for aspiring data scientists? How can individuals effectively utilize this roadmap to progress...
0
by: Hystou | last post by:
There are some requirements for setting up RAID: 1. The motherboard and BIOS support RAID configuration. 2. The motherboard has 2 or more available SATA protocol SSD/HDD slots (including MSATA, M.2...
0
by: Hystou | last post by:
Most computers default to English, but sometimes we require a different language, especially when relocating. Forgot to request a specific language before your computer shipped? No problem! You can...
0
Oralloy
by: Oralloy | last post by:
Hello folks, I am unable to find appropriate documentation on the type promotion of bit-fields when using the generalised comparison operator "<=>". The problem is that using the GNU compilers,...
0
by: Hystou | last post by:
Overview: Windows 11 and 10 have less user interface control over operating system update behaviour than previous versions of Windows. In Windows 11 and 10, there is no way to turn off the Windows...
0
tracyyun
by: tracyyun | last post by:
Dear forum friends, With the development of smart home technology, a variety of wireless communication protocols have appeared on the market, such as Zigbee, Z-Wave, Wi-Fi, Bluetooth, etc. Each...
0
agi2029
by: agi2029 | last post by:
Let's talk about the concept of autonomous AI software engineers and no-code agents. These AIs are designed to manage the entire lifecycle of a software development project—planning, coding, testing,...
0
isladogs
by: isladogs | last post by:
The next Access Europe User Group meeting will be on Wednesday 1 May 2024 starting at 18:00 UK time (6PM UTC+1) and finishing by 19:30 (7.30PM). In this session, we are pleased to welcome a new...

By using Bytes.com and it's services, you agree to our Privacy Policy and Terms of Use.

To disable or enable advertisements and analytics tracking please visit the manage ads & tracking page.