- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我正在做一个小项目“ parking 场 table ”。它允许您添加、删除和搜索汽车。除此之外,它还意味着返回已经停放的汽车数量。我的问题是:
如何编写代码来计算使用的行数并返回使用的行数?大概是通过按钮或通过标签自动更新。
注意:抱歉造成困惑。
import java.awt.BorderLayout;
import java.awt.event.ActionEvent;
import java.awt.event.ActionListener;
import java.awt.event.FocusAdapter;
import java.awt.event.FocusEvent;
import java.awt.event.KeyAdapter;
import java.awt.event.KeyEvent;
import java.awt.event.KeyListener;
import javax.swing.JButton;
import javax.swing.JFrame;
import javax.swing.JOptionPane;
import javax.swing.JPanel;
import javax.swing.JScrollPane;
import javax.swing.JTable;
import javax.swing.JTextField;
import javax.swing.RowFilter;
import javax.swing.table.DefaultTableModel;
import javax.swing.table.TableModel;
import javax.swing.table.TableRowSorter;
public class ParkingTable {
public static void main(String args[]) {
JFrame frame = new JFrame("Car Parking Table");
frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
/**********************************************************************/
String columns[] = { "Reg","Bay" };
Object rows[][] = {
//Population
{ "IL39D", 1 },
{ "HEL39D", 2 },
{ "AD903", 3 },
{ "TE3P3P", 4 },
{ "EPO338C", 5 },
{ "J03C33", 6 },
{ "AOEC3CC", 7 },
{ "VVVAV33", 8 },
{ "AVARG033", 9 },
{ "AEED33", 10 }, };
TableModel model = new DefaultTableModel(rows, columns) {
public Class getColumnClass(char column) {
Class returnValue;
if ((column >= -1) && (column < getColumnCount())) {
returnValue = getValueAt(-1, column).getClass();
} else {
returnValue = Object.class;
}
return returnValue;
}
};
/**********************************************************************/
final JTable table = new JTable(model);
final TableRowSorter<TableModel> sorter = new TableRowSorter<>(model);
table.setRowSorter(sorter);
/**********************************************************************/
//Table
JScrollPane scrTable = new JScrollPane(table);
frame.add(scrTable , BorderLayout.CENTER);
//Panel
JPanel panel = new JPanel(new BorderLayout());
frame.add(panel, BorderLayout.NORTH);
/**********************************************************************/
//Find The Car
final JTextField tfFilter = new JTextField();
tfFilter.addFocusListener(new FocusAdapter() {
public void focusGained(FocusEvent fEvt){
tfFilter.setText("Enter The Reg Number To Find The Car");
tfFilter.selectAll();
}
});
tfFilter.addKeyListener(new KeyAdapter(){
public void keyReleased(KeyEvent e){
String st=tfFilter.getText();
tfFilter.setText(st.toUpperCase());
}
});
/**********************************************************************/
//Reg Number
final JTextField tfReg= new JTextField("Enter Car Reg");
tfReg.addFocusListener(new FocusAdapter() {
public void focusGained(FocusEvent fEvt){
tfReg.setText("Enter Car Reg");
tfReg.selectAll();
}
});
tfReg.addKeyListener(new KeyAdapter(){
public void keyReleased(KeyEvent e){
String st=tfReg.getText();
tfReg.setText(st.toUpperCase());
}
});
/**********************************************************************/
//Bay Number
final JTextField tfBay= new JTextField("Enter The Bay NUMBER");
tfBay.addFocusListener(new FocusAdapter() {
public void focusGained(FocusEvent fEvt){
tfBay.setText("Enter The Bay NUMBER");
tfBay.selectAll();
}
});
tfBay.addKeyListener(new KeyAdapter(){
public void keyTyped(KeyEvent e){
char vChar=e.getKeyChar();
if(!(Character.isDigit(vChar)||
(vChar== KeyEvent.VK_BACK_SLASH)||
(vChar==KeyEvent.VK_DELETE))){
e.consume();
}
}
});
/**********************************************************************/
//Butons
JButton btnFilter = new JButton("Filter");
JButton btnAdd = new JButton ("Add");
JButton btnDelete=new JButton("Delete");
//Filter For The Reg
btnFilter.addActionListener(new ActionListener() {
public void actionPerformed(ActionEvent e) {
String text = tfFilter.getText();
if (text.length() == 0) {
sorter.setRowFilter(null);
} else {
sorter.setRowFilter(RowFilter.regexFilter(text));
}
}
});
/**********************************************************************/
//Add Car To Bay
btnAdd.addActionListener(new ActionListener(){
@Override
public void actionPerformed(ActionEvent e) {
DefaultTableModel model=(DefaultTableModel) table.getModel();
if(!tfReg.getText().trim().equals("")){
model.addRow(new Object[]{tfReg.getText(),tfBay.getText()});
}
}
});
/**********************************************************************/
//Delete The Selected Car
btnDelete.addActionListener(new ActionListener() {
@Override
public void actionPerformed(ActionEvent e) {
DefaultTableModel model=(DefaultTableModel) table.getModel();
if(table.getSelectedRow()==-1){
if(table.getRowCount()==0){
}
}else{
model.removeRow((table.getSelectedRow()));
}
}
});
/**********************************************************************/
//Placing Of Buttons And Text Boxes
frame.add(btnFilter, BorderLayout.SOUTH);
frame.add(btnAdd, BorderLayout.WEST);
frame.add(btnDelete, BorderLayout.EAST);
panel.add(tfReg,BorderLayout.CENTER);
panel.add(tfBay,BorderLayout.AFTER_LAST_LINE);
panel.add(tfFilter,BorderLayout.BEFORE_FIRST_LINE);
frame.setSize(350, 350);
frame.setVisible(true);
}
}
最佳答案
您可以使用 model.getRowCount()
方法返回表中的行数。吨
您还可以限制您的模型以包含使用 this constructor 创建数据模型的特定行数.
public DefaultTableModel(Vector columnNames,
int rowCount)
关于java - JTable 计算正在使用的行数并返回数字,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/22867838/
我有一个包含未定义条目数的数据文件,如下所示: A B C D E.. 1 0 2 5 4 7 4 3 4 1 8 7 4 0 7 1 1 第一行代表工作时间,而不是暂停等交替方式。为了可
我需要有关小型 SQL 查询的帮助。考虑下表: TicketNo | Rules | Audit Result --------------------------------- P
我有一个非常大的表(~1 000 000 行)和带有联合、连接和 where 语句的复杂查询(用户可以选择不同的 ORDER BY 列和方向)。我需要获取分页的行数。如果我运行查询而不计算行数,它会很
我想获取数据帧的行数。 我可以通过 size(myDataFrame)[1] 实现这一点. 有更干净的方法吗? 最佳答案 如果您正在使用 DataFrames具体来说,那么你可以使用 nrow() :
是否可以在带有千位分隔符的 VIM 状态栏中显示行数,最好是自定义千位分隔符? 例子: set statusline=%L 应该导致“1,234,567”而不是“1234567”。 最佳答案 我找到了
我有一个非常基本的问题,但不知道该怎么做。如果 mysql 表中的行数增加,我想刷新页面。我已经尝试了一些不同的事情,比如在表中添加一个单独的列,如果行数和这个值相等,则值为 (id + 1),然后进
我的 mysql TB 中的行数(如 TB 信息中所示)是 11093,而自动递增 ID(从 1 开始)是 11361。为什么会这样? 最佳答案 删除的行不会重置 AI 索引。行数是当前表中的条目数,
我有一个 MySQL 表如下。 emp_no emp_name dob gender 1 A 1978-10-10 Male 2 B
ifstream inFile; inFile.open(filename); //open the input file stringstream strStream; strStream << i
SELECT * FROM table1 WHERE EXISTS (SELECT * FROM table2 WHERE *condition*) 例如,我可以检查是否有 3 行符合 table2
我正在尝试提取 SQL 表中的总行数。 我正在使用以下代码: $rowNum = mysql_query("SELECT COUNT(*) FROM Logs"); $count = mysql_fe
我想知道表格 View 的行宽是多少,UITableViewCell 文本标签的字体是什么,有人可以帮我吗? 最佳答案 NSLog(@"width: %f", cell.frame.size.widt
对于以下内容: def linecount(filename): count = 0 for x in open(filename): count += 1 r
感谢关注。 我用C语言写了一段代码来统计字数、行数和字符数。 while((c = fgetc(fp)) != EOF) { if((char)(c) == ' ' || (char)(c)
我是 matlab 的新手,只需要更改代码中的一个非常小的东西。我有以下矩阵: ans = 1 1 1 1 2 1 2 1
我只是想弄清楚如何确定行数,然后使该数字显示在 HTML 中。 我准备好的声明如下所示: if($stmt = $mysqli -> prepare("SELECT field1, field2, f
PDO 显然无法计算从选择查询返回的行数(mysqli 有 num_rows 变量)。 除了使用 count($results->fetchAll()) 之外,有没有办法做到这一点? 最佳答案 根据手
SELECT count(*) FROM Stack WHERE Id = 33478 GROUP BY SID Output: (No column name) 1 4 对于结果;有两排。怎么退货
IE。如果我们有一个包含400万行的表。 其中具有一个STATUS字段,该字段可以采用以下值:TO_WORK,BLOCKED或WORKED_CORRECTLY。 您是否会在一个仅会更改一次的字段上进行
所以在JTextArea中有一个getLineCount()是否有与JTextPane类似的东西,因为我可以找到任何东西。也许有不同的方法来获得它?我想获取当前存在的行数。 最佳答案 (正如您所指出的
我是一名优秀的程序员,十分优秀!