NPOI Issues Closing new doc files
up vote
0
down vote
favorite
I'm going insane trying to understand why I can't write a new file. I've found some examples which say to write files following this like this:
public void WriteFile(string filename, IEnumerable<string> paragraphs)
{
var docStream = new POIFSFileSystem(File.OpenRead("empty.doc"));
var doc = new HWPFDocument(docStream);
var range = doc.GetRange();
foreach (var para in paragraphs)
{
range.InsertAfter(para);
}
DocumentSummaryInformation dsi = doc.DocumentSummaryInformation;
var cp = dsi.CustomProperties;
if (cp == null)
cp = new NPOI.HPSF.CustomProperties();
cp.Put("myProperty", "foo bar baz");
doc.Write(File.OpenWrite(filename));
}
After the execution of that method I want to read all the bytes from a file and return the content to the browser which invoked all this (from ASP.NET CORE):
byte fileBytes = System.IO.File.ReadAllBytes(path);
var result = File(fileBytes, "application/msword", path);
//System.IO.File.Delete(path);
var retObj = Newtonsoft.Json.JsonConvert.SerializeObject(new {filePath = path});
return Task.FromResult(retObj);
The ReadAllBytes line as well as an attempt to open the file from Windows Explorer whilst debugging gives an error about the file being in use by another process. If I stop the website execution and try explorer again I'm told the file is corrupt! None of the NPOI classes are disposable here and the POIFSFileSystem.Close method from POI isn't implemented in NPOI so I have to assume it's closed implicitly.
Anyone know how to cleanly close and release the file?
Or can anyone recommend a 'good' library that isn't so mysterious to use for processing and creating MS Office documents?
.net apache-poi npoi
add a comment |
up vote
0
down vote
favorite
I'm going insane trying to understand why I can't write a new file. I've found some examples which say to write files following this like this:
public void WriteFile(string filename, IEnumerable<string> paragraphs)
{
var docStream = new POIFSFileSystem(File.OpenRead("empty.doc"));
var doc = new HWPFDocument(docStream);
var range = doc.GetRange();
foreach (var para in paragraphs)
{
range.InsertAfter(para);
}
DocumentSummaryInformation dsi = doc.DocumentSummaryInformation;
var cp = dsi.CustomProperties;
if (cp == null)
cp = new NPOI.HPSF.CustomProperties();
cp.Put("myProperty", "foo bar baz");
doc.Write(File.OpenWrite(filename));
}
After the execution of that method I want to read all the bytes from a file and return the content to the browser which invoked all this (from ASP.NET CORE):
byte fileBytes = System.IO.File.ReadAllBytes(path);
var result = File(fileBytes, "application/msword", path);
//System.IO.File.Delete(path);
var retObj = Newtonsoft.Json.JsonConvert.SerializeObject(new {filePath = path});
return Task.FromResult(retObj);
The ReadAllBytes line as well as an attempt to open the file from Windows Explorer whilst debugging gives an error about the file being in use by another process. If I stop the website execution and try explorer again I'm told the file is corrupt! None of the NPOI classes are disposable here and the POIFSFileSystem.Close method from POI isn't implemented in NPOI so I have to assume it's closed implicitly.
Anyone know how to cleanly close and release the file?
Or can anyone recommend a 'good' library that isn't so mysterious to use for processing and creating MS Office documents?
.net apache-poi npoi
add a comment |
up vote
0
down vote
favorite
up vote
0
down vote
favorite
I'm going insane trying to understand why I can't write a new file. I've found some examples which say to write files following this like this:
public void WriteFile(string filename, IEnumerable<string> paragraphs)
{
var docStream = new POIFSFileSystem(File.OpenRead("empty.doc"));
var doc = new HWPFDocument(docStream);
var range = doc.GetRange();
foreach (var para in paragraphs)
{
range.InsertAfter(para);
}
DocumentSummaryInformation dsi = doc.DocumentSummaryInformation;
var cp = dsi.CustomProperties;
if (cp == null)
cp = new NPOI.HPSF.CustomProperties();
cp.Put("myProperty", "foo bar baz");
doc.Write(File.OpenWrite(filename));
}
After the execution of that method I want to read all the bytes from a file and return the content to the browser which invoked all this (from ASP.NET CORE):
byte fileBytes = System.IO.File.ReadAllBytes(path);
var result = File(fileBytes, "application/msword", path);
//System.IO.File.Delete(path);
var retObj = Newtonsoft.Json.JsonConvert.SerializeObject(new {filePath = path});
return Task.FromResult(retObj);
The ReadAllBytes line as well as an attempt to open the file from Windows Explorer whilst debugging gives an error about the file being in use by another process. If I stop the website execution and try explorer again I'm told the file is corrupt! None of the NPOI classes are disposable here and the POIFSFileSystem.Close method from POI isn't implemented in NPOI so I have to assume it's closed implicitly.
Anyone know how to cleanly close and release the file?
Or can anyone recommend a 'good' library that isn't so mysterious to use for processing and creating MS Office documents?
.net apache-poi npoi
I'm going insane trying to understand why I can't write a new file. I've found some examples which say to write files following this like this:
public void WriteFile(string filename, IEnumerable<string> paragraphs)
{
var docStream = new POIFSFileSystem(File.OpenRead("empty.doc"));
var doc = new HWPFDocument(docStream);
var range = doc.GetRange();
foreach (var para in paragraphs)
{
range.InsertAfter(para);
}
DocumentSummaryInformation dsi = doc.DocumentSummaryInformation;
var cp = dsi.CustomProperties;
if (cp == null)
cp = new NPOI.HPSF.CustomProperties();
cp.Put("myProperty", "foo bar baz");
doc.Write(File.OpenWrite(filename));
}
After the execution of that method I want to read all the bytes from a file and return the content to the browser which invoked all this (from ASP.NET CORE):
byte fileBytes = System.IO.File.ReadAllBytes(path);
var result = File(fileBytes, "application/msword", path);
//System.IO.File.Delete(path);
var retObj = Newtonsoft.Json.JsonConvert.SerializeObject(new {filePath = path});
return Task.FromResult(retObj);
The ReadAllBytes line as well as an attempt to open the file from Windows Explorer whilst debugging gives an error about the file being in use by another process. If I stop the website execution and try explorer again I'm told the file is corrupt! None of the NPOI classes are disposable here and the POIFSFileSystem.Close method from POI isn't implemented in NPOI so I have to assume it's closed implicitly.
Anyone know how to cleanly close and release the file?
Or can anyone recommend a 'good' library that isn't so mysterious to use for processing and creating MS Office documents?
.net apache-poi npoi
.net apache-poi npoi
asked Nov 21 at 12:22
Stephen York
4471418
4471418
add a comment |
add a comment |
active
oldest
votes
active
oldest
votes
active
oldest
votes
active
oldest
votes
active
oldest
votes
Thanks for contributing an answer to Stack Overflow!
- Please be sure to answer the question. Provide details and share your research!
But avoid …
- Asking for help, clarification, or responding to other answers.
- Making statements based on opinion; back them up with references or personal experience.
To learn more, see our tips on writing great answers.
Some of your past answers have not been well-received, and you're in danger of being blocked from answering.
Please pay close attention to the following guidance:
- Please be sure to answer the question. Provide details and share your research!
But avoid …
- Asking for help, clarification, or responding to other answers.
- Making statements based on opinion; back them up with references or personal experience.
To learn more, see our tips on writing great answers.
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
StackExchange.ready(
function () {
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53411940%2fnpoi-issues-closing-new-doc-files%23new-answer', 'question_page');
}
);
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown