- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在使用下面的方法从用户那里检索文件。但大多数时候它不会弹出。难道我做错了什么?先感谢您。
import javax.swing.JFileChooser;
import javax.swing.JFrame;
import javax.swing.filechooser.FileNameExtensionFilter;
public class FileChooser {
public String getFile(){
//public static void main(String[] args){
JFileChooser fc=new JFileChooser();
JFrame jf = new JFrame("ExcelReading for Updating Columns"); // added
jf.setAlwaysOnTop(true); // added
fc.setDialogTitle("Excel File For Updating Columns");
fc.setApproveButtonText("Choose Excel File");
FileNameExtensionFilter filter = new FileNameExtensionFilter("XLS files", "xls");
jf.setAlwaysOnTop(true); // added
int returnVal=fc.showOpenDialog(jf);
if (returnVal == JFileChooser.APPROVE_OPTION) {
return fc.getSelectedFile().getAbsolutePath();
}
else return null;
}
}
编辑添加了以下信息:
主要方法:使用该类读取excel表格中的信息。我相信我的方法 showMessage 和 JOptionPane.showMessageDialog 方法是造成这种情况的原因。
import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.IOException;
import java.util.Iterator;
import java.util.ArrayList;
import javax.swing.JOptionPane;
import org.apache.poi.hssf.usermodel.HSSFSheet;
import org.apache.poi.hssf.usermodel.HSSFWorkbook;
import org.apache.poi.ss.usermodel.Cell;
import org.apache.poi.ss.usermodel.Row;
public class ReadFromExcel {
public static void main(String[] args)
{
/*
*
*
* Gets wanted info from excel file. puts them into an Student ArrayList and given to AddingToDatabase.java to enter to database
* This goes through and reads every single row
* then goes onto the next row
*
* to do:
* go down one column at a time.
*/
FileChooser fc= new FileChooser();
int desiredColumn=0;
String file;
String out=" ";
String answer="n";
showMessage("This program will ask you which columns you will want to update to the database. "
+ "\nPlease add all students to the database first before running this program.");
boolean repeat=false;
do{
showMessage("Please select the file you want to get data from");
file = fc.getFile();
if (file==null){
repeat=false;
out="You did not select a file. ";
}
else{
String sheet = JOptionPane.showInputDialog(null, "Enter the name of the sheet you want information from\n*Case Sensitive*");
desiredColumn = Integer.parseInt(JOptionPane.showInputDialog(null, "Which column would you like to update? You must enter a number:"
+ "\nChapter Paid=2"
+ "\nNational Paid=3"
+ "\nLast Name=4"
+ "\nFirst Name=5"
+ "\nEmail=6"
+ "\nMajor=8"
+ "\nYear=9"));
/*System.out.println("Which column would you like to update? You must enter a number: "
+ "\nChapter Paid=2"
+ "\nNational Paid=3"
+ "\nLast Name=4"
+ "\nFirst Name=5"
+ "\nEmail=6"
+ "\nMajor=8"
+ "\nYear=9");*/
if(desiredColumn == 2||desiredColumn==3|desiredColumn==4||desiredColumn==5||desiredColumn==6||desiredColumn==8||desiredColumn==9)
{
int k=JOptionPane.showConfirmDialog(null, "Confirm following information:\nFilepath: "+file+"\nSheet name: "+sheet+"\nColumn to be updated: "+desiredColumn);
if(k!=0)
{
break;
}
else
complete(desiredColumn);
}
else
showMessage(out+"You didn't choose a valid column");
//System.out.println("Would you like to do another update? y/n?");
answer = JOptionPane.showInputDialog(null,"Would you like to do another update? y/n?");
if(answer.charAt(0)=='y')
{
repeat=true;
}
else
{
repeat=false;
}
}
}while(repeat);
showMessage(out+"Program will now terminate");
System.exit(0);
}
public static void complete(int desiredColumn){
try
{
String fName=null;
String lName=null;
int SID = 0;
String email=null;
boolean chapterPaid=false;
boolean nationalPaid=false;
String major=null;
String year=null;
String temp=null;
int tempInt=0;
//UpdateToDatabase addD= new UpdateToDatabase();
UpdateByPHP php=new UpdateByPHP();
//this is starting at 2nd row(where the values start)
int currentRow=2;
//this starts at the first cell
int currentCell=1;
//stating exactly which cells i want information from. cells start at 1 which is defined by the currentCell above.
final int chapterPaidCell=2;
final int nationalPaidCell=3;
final int lnameCell=4;
final int fnameCell=5;
final int emailCell=6;
final int studIDCell=7;
final int majorCell=8;
final int yearCell=9;
ArrayList<Students> array= new ArrayList<Students>();
FileInputStream fileInputStream = new FileInputStream("/Users/jashmit/Desktop/Workbook2.xls");
HSSFWorkbook workbook = new HSSFWorkbook(fileInputStream);
HSSFSheet worksheet = workbook.getSheet("Sheet1");
Iterator<Row> rowIterator = worksheet.iterator();
//moves toward starting row. not really needed.
for (int i=1; i<currentRow; i++)
{
rowIterator.next();//skip row of titles
}
while (rowIterator.hasNext())//top to bottom
{
//variables to be added to database
//so variables reset every line
fName=null;
lName=null;
SID = 0;
email=null;
chapterPaid=false;
nationalPaid=false;
major=null;
Row row = rowIterator.next();
Iterator <Cell> cellIterator = row.cellIterator();
while (cellIterator.hasNext()) //columns, left to right
{
Cell cell = cellIterator.next();
if(currentCell==chapterPaidCell && currentCell==desiredColumn)
{
if(cell.getStringCellValue().toLowerCase().equals("yes"))
{
chapterPaid=true;
}
else
{
chapterPaid=false;
}
}
else if(currentCell==nationalPaidCell && currentCell==desiredColumn)
{
if(cell.getStringCellValue().toLowerCase().equals("yes"))
{
nationalPaid=true;
}
else
nationalPaid=false;
}
else if(currentCell==lnameCell && currentCell==desiredColumn)
{
lName=cell.getStringCellValue();
}
else if(currentCell==fnameCell && currentCell==desiredColumn)
{
fName=cell.getStringCellValue();
}
else if(currentCell==emailCell && currentCell==desiredColumn)
{
email=cell.getStringCellValue();
}
else if(currentCell==studIDCell)
{
SID=(int) cell.getNumericCellValue();
}
else if (currentCell==majorCell && currentCell==desiredColumn)
{
major=cell.getStringCellValue();
}
else if (currentCell==yearCell && currentCell==desiredColumn)
{
temp=cell.getStringCellValue();
tempInt=temp.indexOf('(');
if(tempInt==-1)
{
year=cell.getStringCellValue();
}
else
{
year=temp.substring(0,tempInt);
}
}
currentCell++;
}
currentCell=1;
array.add(new Students(fName,lName, SID ,email,chapterPaid,nationalPaid,major,year));
}
//now after reading from excel, put info into database
workbook.close();
php.writePHP(array, desiredColumn);
return;
}
catch (FileNotFoundException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
}
}
public static void showMessage(String text)
{
JOptionPane.showMessageDialog(null, text);
}
}
最佳答案
您不需要额外的 JFrame 来显示 JFileChooser。这是您修改后的代码。
public class FileChooser {
public String getFile(){
//public static void main(String[] args){
JFileChooser fc=new JFileChooser();
fc.setDialogTitle("Excel File For Updating Columns");
fc.setApproveButtonText("Choose Excel File");
FileNameExtensionFilter filter = new FileNameExtensionFilter("XLS files", "xls");
int returnVal=fc.showOpenDialog(null);
if (returnVal == JFileChooser.APPROVE_OPTION) {
return fc.getSelectedFile().getAbsolutePath();
}
else return null;
}
public static void main(String[] args) {
new FileChooser().getFile();
}
}
关于java - JFileChooser.showOpenDialog(new JFrame());不弹出,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32291830/
我连续有 11 个图像,如果鼠标悬停在其中一个图像上,我希望弹出一个弹出窗口。所以每 11 个图像都有不同的弹出窗口。我已经有一些代码可以执行此操作,但它仅适用于第一张图像。 代码:index.htm
是否可以从 NSColorWell 制作一个 NSColorPanel“弹出”,几乎像一个弹出菜单? 我不喜欢它作为调色板的实现方式,因为有时它与哪个 NSColorWell 关联并不明显。 谢谢!
我正在考虑一个想法,基本上我想要一个带有 NSPopoverController 的 NSStatusItem 。我读到了人们遇到的所有问题,但我只是想尝试一下。现在有干净的方法吗?我见过的所有版本都
如何获取 JS 打开的弹出窗口的 url。这是我的代码: var _url = 'someurlhere'; var popupwindow = window.open(_url, "Popu
我正在设计一个网页,我希望当用户单击链接时,弹出窗口(新窗口)将打开一个链接网页。我的代码如下所示 function win(add,w,h) { window.open(add,"","widt
我正在寻找 C 中的简单堆栈实现,并找到了类似的东西: void pop(struct stack **top) { struct stack *temp; temp = malloc(s
我正在尝试使用 paypal 实现登录,我有 2 个不同的主机域 1- www.example.com 2- www.example.de 对于 paypal,我需要为此目的选择一个返回 URL,我选
我正在尝试找出如何复制此处显示的“弹出式” View 动画:https://imgur.com/a/irFqdiP .我正在使用当前代码来显示我的 viewController,但目前只有一个淡入淡出
有谁知道在 Windows 2000 或更高版本上以编程方式关闭 CD 托盘的方法?打开 CD 托盘存在,但我似乎无法关闭它,尤其是在 W2k 下。 如果可能的话,我特别想从批处理文件中寻找一种方法来
当您访问http://www.daniweb.com时你得到一个弹出窗口,这叫什么 + 知道怎么做吗? 感谢您的回复,只有模态加载动画的最简单方法是什么,即页面加载时动画显示以及动画何时完成? ASP
我正在为 Unity 引擎中的音频过滤器创建一个 C# 脚本。 我的问题是,在通过我的过滤器运行后,生成的音频具有一致且频繁的“咔哒声”、“砰砰声”或“跳过声”。听起来有点像旧 radio 。 我不确
我必须隐藏浏览器的地址栏。我正在使用这段代码: var winFeature = 'location=no,toolbar=no,menubar=no,scrollbars=yes,r
推荐一个button 弹起pickerview的源码,也可以作为工具类使用。 利用inputview 做键盘弹起动画。该如何做呢? 1.继承uiview 2.重写属性&方法
我在这里有一个问题,我已经工作了几个小时。 我正在导入一个 Excel 文件,并使用此代码来执行此操作: Dim objExcel As Excel.Application Di
我基本上是从 UITableViewController 推送 UIView,它包含的只是 UIWebView。但是,当我删除 UIView 以返回到 UITableView 时,应用程序崩溃了。 -
我有几个由导航 Controller 控制的 View Controller 。 例如,viewController A 和 viewController B 都可以将 viewController
我使用新的Gmail API为用户创建草稿。 API响应提供了新创建的消息ID。 然后,我可以使用URL https://mail.google.com/mail/#drafts?compose=[m
Redis列表实现了哪种内部数据结构以实现这一目的?链表将需要O(n)索引,而数组将需要O(n)左/右推/弹出。 最佳答案 根据official documentation,它们被实现为linked
我正在使用 WPF Popup 控件,它显示背景为黑色。我在其中放置了一个 StackPanel 并设置了 Background="Transparent",但这没有帮助。
我希望页面内的容器在事件时占据页面的整个宽度并覆盖在其他所有内容上。这是我目前所拥有的,但它没有按我想要的方式工作: $(function() { $('.main a').click( fu
我是一名优秀的程序员,十分优秀!