java怎样从txt文件中读内容显示到JTextArea中

求将txt中多行内容显示到JTextArea中的代码,谢谢。... 求将txt中多行内容显示到JTextArea中的代码,谢谢。 展开
 我来答
百度网友5ca104357
推荐于2017-12-16 · TA获得超过2595个赞
知道小有建树答主
回答量:874
采纳率:100%
帮助的人:1361万
展开全部
//包你满意

import java.awt.BorderLayout;
import java.awt.Color;
import java.awt.Font;
import java.awt.HeadlessException;
import java.awt.event.ActionEvent;
import java.awt.event.ActionListener;
import java.io.BufferedReader;
import java.io.File;
import java.io.FileInputStream;
import java.io.InputStreamReader;

import javax.swing.JButton;
import javax.swing.JFileChooser;
import javax.swing.JFrame;
import javax.swing.JOptionPane;
import javax.swing.JPanel;
import javax.swing.JScrollPane;
import javax.swing.JTextArea;
import javax.swing.filechooser.FileFilter;

/**
* @author wsj
* @date 2010-5-27, 下午09:10:10
*/
public class JTextAreaTest extends JFrame implements ActionListener{
JTextArea area=new JTextArea(20, 50);
private JButton btn=new JButton("读取文件到JTextArea...");

public JTextAreaTest(String title) throws HeadlessException {
super(title);
setBounds(100,100,900,500);
setVisible(true);
setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
area.setFont(new Font("宋体", Font.PLAIN,16));
area.setForeground(Color.red);
add(new JScrollPane(area),BorderLayout.CENTER);
JPanel panel=new JPanel();
panel.add(btn);
btn.addActionListener(this);
add(panel,BorderLayout.SOUTH);
validate();
}

public static void main(String[] args) {
new JTextAreaTest("JTextArea测试");
}

@Override
public void actionPerformed(ActionEvent e) {
if(e.getSource()==btn){
new FileReadThread(this).start();//开启文件读取线程
}
}
}
/**
* 文件读取线程
*/
class FileReadThread extends Thread{
private JTextAreaTest test;

public FileReadThread(JTextAreaTest test) {
this.test = test;
}

@Override
public void run() {
JFileChooser chooser=new JFileChooser("d:/");
chooser.setFileFilter(new FileFilter() {//定义文件过滤器,仅显示文件夹和txt文本

@Override
public String getDescription() {
return null;
}

@Override
public boolean accept(File file) {
if(file.isDirectory()||file.getName().endsWith(".txt"))
return true;
return false;
}
});
int option=chooser.showOpenDialog(test);
if(option==JFileChooser.APPROVE_OPTION){
File selFile=chooser.getSelectedFile();
try {
BufferedReader reader=new BufferedReader(new InputStreamReader(new FileInputStream(selFile),"gbk"));
String line=null;
while ((line=reader.readLine())!=null) {
test.area.append(line+"\n");
Thread.sleep(30);//线程暂停,以看到读取过程效果
}
} catch (Exception e1) {
e1.printStackTrace();
}
JOptionPane.showMessageDialog(test, "读取完毕");
}

}

}

参考资料: 还有其他问题的话,给我发百度消息

本回答被提问者采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
TableDI
2024-07-18 广告
在上海悉息信息科技有限公司,我们深知Excel在数据处理中的重要作用。在Excel中引用不同工作表(sheet)的数据是常见的操作,这有助于整合和分析跨多个工作表的信息。通过在工作表名称前加上感叹号“!”,您可以轻松地引用其他工作表中的数据... 点击进入详情页
本回答由TableDI提供
布尔值
2010-05-27 · TA获得超过379个赞
知道小有建树答主
回答量:310
采纳率:0%
帮助的人:242万
展开全部
用IO字节流和字符流
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 1条折叠回答
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式