[英]Writing Console Output to File in Java
所以我想知道是否可以将所有控制台 output 写入 Java 之外的单独文件中? 我知道 Printwriter 和 Filewriter 方法。 但是,根据我的经验,如果我在一种方法中全部使用它们,它们会起作用,但我认为我不能用我现在拥有的代码来做到这一点。 下面是我所拥有的...
Java代码
import java.io.BufferedWriter;
import java.io.File;
import java.io.FileWriter;
import java.io.IOException;
import java.io.PrintWriter;
import org.xml.sax.*;
import org.xml.sax.helpers.DefaultHandler;
import javax.xml.parsers.SAXParser;
import javax.xml.parsers.SAXParserFactory;
public class XMLTagParser extends DefaultHandler
{
private int i;
public XMLTagParser()
{
traverse(new File("C:/Documents and Settings/user/workspace/Intern Project/Proposals/Converted Proposals/Extracted Items"));
}
private static final class SaxHandler extends DefaultHandler
{
private StringBuffer buffer;
private String heading;
private boolean inHeading;
public void startElement(String uri, String localName, String qName, Attributes attrs)
{
if ("w:pStyle".equals(qName))
{
String val = attrs.getValue("w:val");
if (val.contains("Heading"))
{
if (isHeading(val))
{
System.out.println(val);
inHeading = true;
}
}
}
if("w:t".equals(qName))
{
if (inHeading == true)
{
buffer = new StringBuffer();
}
}
}
public void characters(char buff[], int offset, int length) throws SAXException
{
String s = new String(buff, offset, length);
if(buffer != null)
{
buffer.append(s);
heading = heading += s;
}
}
public void endElement(String uri, String localName, String qName)
{
buffer = null;
//if the qName is "w:p" and it is in the heading, print out the heading and then reset
if ("w:p".equals(qName) && inHeading == true)
{
System.out.println(heading);
heading = "";
inHeading = false;
}
}
// method to verify whether element is an actual heading
private static boolean isHeading(String heading)
{
String headingNumber = heading.substring(7,8);
String headingName = heading.substring(0,7);
if (headingName.equals("Heading"))
{
if (headingNumber.equals("1")
|| headingNumber.equals("2")
|| headingNumber.equals("3")
|| headingNumber.equals("4")
|| headingNumber.equals("5")
|| headingNumber.equals("6"))
{
return true;
}
}
return false;
}
}
/*private void writeFile(File file)
{
try
{
PrintWriter out = new PrintWriter(new FileWriter(file + "/" + i++));
out.close();
}
catch (IOException e)
{
e.printStackTrace(System.out);
}
}*/
private void traverse(File directory)
{
//Get all files in directory
File[] files = directory.listFiles();
for (File file : files)
{
if (file.getName().equals("document.xml"))
{
try
{
// creates and returns new instance of SAX-implementation:
SAXParserFactory factory = SAXParserFactory.newInstance();
// create SAX-parser...
SAXParser parser = factory.newSAXParser();
// prints out the current working proposal, traversing up the directory structure
System.out.println(file.getParentFile().getParentFile().getName());
// .. define our handler:
SaxHandler handler = new SaxHandler();
// and parse:
parser.parse(file.getAbsolutePath(), handler);
try
{
// instantiates new printwriter which writes out to a file
PrintWriter out = new PrintWriter(new FileWriter(file.getParentFile().getParentFile() + "/" + i++ + ".txt"));
out.close();
}
catch (IOException e)
{
e.printStackTrace(System.out);
}
}
catch (Exception ex)
{
ex.printStackTrace(System.out);
}
}
else if (file.isDirectory())
{
//It's a directory so (recursively) traverse it
traverse(file);
}
}
}
}
所以我已经在其中实例化了 printwriter,但是如果我没有什么可写的,那显然是不好的。 所以我不太确定如何才能将控制台打印的内容写入该文件。 有任何想法吗? 提前致谢。
如果您开始滚动自己的文件记录器,您将花费更多时间处理 io 问题、滚动文件、文件大小等。 您应该改用log4j ! 它将处理这样的事情并使您的日志记录更加灵活。 这几乎是 java 日志记录的标准。
如果您真的愿意,可以将System.out
重定向到任何PrintStream
,如下所示:
PrintStream stream = new PrintStream("filename.txt");
System.setOut(stream);
System.out 基本上是一个 OutputStream; 默认情况下指向控制台。 相反,您可以创建一个指向您选择的文件的新 FileOutputStream 实例,并通过 System.setOut 对其进行设置来识别此 stream。 这将在程序/应用程序的整个生命周期中为您完成。 检查此链接以获取完整代码。
您可以使用 FileWriter,写入并刷新它,而不是使用 System.out。 目前尚不清楚为什么要在代码中增加 i 。 我猜你想把所有东西都写到一个文件中。
此外,您似乎从未向初始化的 Writer 写入数据。
您可以继续使用 System.out,并在调用应用程序时使用“>”将其重定向到文件。 您仍然可以为直接控制台 output 保留 stderr。 或者当你写“在java之外”时你的意思是什么?
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.