- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有一个包含许多列的 TableView。第一个包含日期(以 dd/mm/yyyy
格式),但日期没有“正确”排序。
这是我一直在准备的一个小例子:
这是代码:
测试.java
package test;
import javafx.application.Application;
import javafx.fxml.FXMLLoader;
import javafx.scene.Scene;
import javafx.scene.layout.AnchorPane;
import javafx.stage.Stage;
public class Test extends Application {
private AnchorPane rootLayout;
@Override
public void start(Stage primaryStage) throws Exception{
FXMLLoader loader = new FXMLLoader();
loader.setLocation(Test.class.getResource("FXMLDocument.fxml"));
FXMLDocumentController controller = new FXMLDocumentController();
loader.setController(controller);
rootLayout = (AnchorPane) loader.load();
Scene scene = new Scene(rootLayout);
primaryStage.setScene(scene);
primaryStage.setTitle("Test");
primaryStage.centerOnScreen();
primaryStage.show();
}
}
package test;
import java.util.List;
import java.util.Map;
import javafx.fxml.FXML;
import javafx.collections.FXCollections;
import javafx.collections.ObservableList;
import javafx.scene.control.TableColumn;
import javafx.scene.control.TableView;
import javafx.scene.control.cell.PropertyValueFactory;
public class FXMLDocumentController {
private ObservableList<ExampleTable> datos;
@FXML public TableView<ExampleTable> tv_example;
@FXML public TableColumn<ExampleTable, String> col_date, col_name;
public void initialize(){
datos = FXCollections.observableArrayList();
col_date.setCellValueFactory(new PropertyValueFactory<>("date"));
col_name.setCellValueFactory(new PropertyValueFactory<>("name"));
setTable();
}
public void setTable(){
List<Map<String, String>> lmap = ExampleTable.lmap();
for(Map<String, String> element : lmap){
ExampleTable objEt = new ExampleTable(element.get("date"), element.get("name"));
datos.add(objEt);
}
tv_example.setItems(datos);
tv_example.getSortOrder().setAll(col_date);
}
}
package test;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import javafx.beans.property.SimpleStringProperty;
import javafx.beans.property.StringProperty;
public class ExampleTable {
public StringProperty date;
public StringProperty name;
public ExampleTable(String date, String name){
this.date = new SimpleStringProperty(date);
this.name = new SimpleStringProperty(name);
}
public String getDate(){
return date.get();
}
public void setDate(String date){
this.date.set(date);
}
public String getName(){
return name.get();
}
public void setName(String name){
this.name.set(name);
}
public static List<Map<String, String>> lmap(){
List<Map<String, String>> list = new ArrayList<>();
Map<String, String> row = new HashMap<>();
row.put("date", "14/01/1988");
row.put("name", "Hagen");
list.add(row);
row = new HashMap<>();
row.put("date", "27/02/1988");
row.put("name", "Herrman");
list.add(row);
row = new HashMap<>();
row.put("date", "16/03/1988");
row.put("name", "Hank");
list.add(row);
row = new HashMap<>();
row.put("date", "19/05/1994");
row.put("name", "Jack");
list.add(row);
return list;
}
}
<?xml version="1.0" encoding="UTF-8"?>
<?import javafx.scene.control.TableColumn?>
<?import javafx.scene.control.TableView?>
<?import javafx.scene.layout.AnchorPane?>
<?import javafx.scene.layout.VBox?>
<AnchorPane id="AnchorPane" prefHeight="400.0" prefWidth="500.0" xmlns:fx="http://javafx.com/fxml/1" xmlns="http://javafx.com/javafx/8.0.111">
<children>
<VBox layoutX="32.0" layoutY="40.0" prefHeight="200.0" prefWidth="100.0" AnchorPane.bottomAnchor="4.0" AnchorPane.leftAnchor="4.0" AnchorPane.rightAnchor="4.0" AnchorPane.topAnchor="4.0">
<children>
<TableView fx:id="tv_example" maxHeight="1.7976931348623157E308" prefWidth="200.0" VBox.vgrow="ALWAYS">
<columns>
<TableColumn fx:id="col_date" minWidth="120.0" prefWidth="120.0" text="Date" />
<TableColumn fx:id="col_name" minWidth="100.0" prefWidth="300.0" text="Name" />
</columns>
</TableView>
</children>
</VBox>
</children>
</AnchorPane>
public ObjectProperty<LocalDate> date;
public StringProperty name;
public ExampleTable(LocalDate date, String name){
this.date = new SimpleObjectProperty(date);
this.name = new SimpleStringProperty(name);
}
public LocalDate getDate(){
return date.get();
}
public void setDate(LocalDate date){
this.date.set(date);
}
public class FXMLDocumentController {
private ObservableList<ExampleTable> datos;
@FXML public TableView<ExampleTable> tv_example;
@FXML public TableColumn<ExampleTable, LocalDate> col_date;
@FXML public TableColumn<ExampleTable, String> col_name;
public void initialize(){
datos = FXCollections.observableArrayList();
col_date.setCellValueFactory(new PropertyValueFactory<>("date"));
col_name.setCellValueFactory(new PropertyValueFactory<>("name"));
setTable();
}
public void setTable(){
List<Map<String, String>> lmap = ExampleTable.lmap();
for(Map<String, String> element : lmap){
LocalDate dt = ExampleTable.toLocalDate(element.get("date"));
ExampleTable objEt = new ExampleTable(dt, element.get("name"));
datos.add(objEt);
}
tv_example.setItems(datos);
tv_example.getSortOrder().setAll(col_date);
}
}
toLocalDate
ExampleTable
中的方法:
public static LocalDate toLocalDate(String date){
final DateTimeFormatter formatter = DateTimeFormatter.ofPattern("dd/MM/yyyy");
LocalDate dt = LocalDate.parse(date, formatter);
return dt;
}
最佳答案
您可以更改方式LocalDate
使用 cellFactory
显示在表格单元格中(除了您已经拥有的 cellValueFactory
):
DateTimeFormatter formatter = DateTimeFormatter.ofPattern("dd/MM/yyyy");
col_date.setCellFactory(tc -> new TableCell<ExampleTable, LocalDate>() {
@Override
protected void updateItem(LocalDate date, boolean empty) {
super.updateItem(date, empty);
if (empty) {
setText(null);
} else {
setText(formatter.format(date));
}
}
});
关于sorting - JavaFX 按日期对 TableView 列进行排序(dd/mm/yyyy 格式),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43851194/
我正在尝试使用这两种格式解析日期 2014-12-03T10:05:59.5646+08:00: yyyy-MM-dd'T'HH:mm:ss yyyy-MM-dd'T'HH:mm:ssXXX 当我使用
Paypal 返回以下格式的时间戳: yyyy-MM-ddTHH:mm:ssZ 我不知道该怎么办... 如何在 php 中使用本地时区将其转换为 yyyy-MM-dd HH:mm:ss? 我很想pre
我正在使用 Excel 2010 或 Excel 2007 导入包含日期/时间信息的 CSV 文件。我的 CSV 文件中的时间戳具有以下格式:yyyy-mm-dd hh:mm:ss。 (例如:2015
这个问题已经有答案了: Separate Date and Time objects (2 个回答) 已关闭 4 年前。 如何从 SimpleDateFormat("MM/dd/yyyy kk:mm"
这个问题已经有答案了: Java string to date conversion (17 个回答) 已关闭 6 年前。 我需要将日期字符串转换为另一种特定格式。 例如:我有一个日期,可以是 YYY
我想将字符串:24/11/2016 04:30 pm 转换为日期时间值:11/24/2016 04:30 pm。 我的代码为: DateTime date = DateTime.ParseExact(
我想使用 linux 将像“26/11/05 06:00:01,057000000”这样的纪元转换为 yyyy-mm-ddThh:mm:ss? 我曾尝试使用以下脚本但没有成功: echo 26/11/
这个问题在这里已经有了答案: mysql YYYY-MM-DDThh:mm:ss (1 个回答) 关闭 6 年前。 我想上传包含 yyyy-mm-ddThh:mm:ss.sssZ 数据的 csv 文
我在“dd-MM-yyyy HH:mm”中有一个字符串,需要将其转换为格式为日期的对象“yyyy-MM-dd HH:mm”。 下面是我用来转换的代码 oldScheduledDate = "16-05
我有一个数据框(df),它有一个日期列(列名:sale_date),它以以下格式存储数据 dd/mm/yy hh:mm:ss 我正在尝试将其转换为 yyyy-mm-dd hh:mm:ss。尝试了以下但
我的数据库中有日期时间列(格式为 YYYY-mm-dd hh:mm:ss)。 我需要将其转换为 dd-mm-YYYY hh:mm:ss 格式。 我该怎么办?帮助我。 最佳答案 不确定如何在 javas
想知道它们是否代表不同的格式或本质上相同(只是新与旧的演示文稿)。 最佳答案 基于DateTimeFormatter : Offset X and x: This formats the offset
如标题所示,我有一个问题。我需要将 LocalDataTime yyyy-MM-ssThh-mm-ss 解析为 LocalDataTime yyyy-MM-ss hh-mm-ss 但是当我这样做时 S
我想用 mySQL 将我的数据从“yyyy-mm-ddThh-mm-ss.sssZ”转换为“yyyy-mm-dd hh-mm-ss”。 我尝试使用 convert_tz: mysql> SELECT
这个问题在这里已经有了答案: LOAD DATA INFILE easily convert YYYYMMDD to YYYY-MM-DD? (1 个回答) 关闭 6 年前。 我正在尝试将 CSV
我需要更改 string 的日期格式。原始字符串的格式如下: var timeStamp = '2014/07/30 - 14:15:36' 这是我想要实现的日期格式: var timeStampAr
我正在尝试将 yyyy-MM-dd'T'HH:mm:ss.SSSz 格式的日期格式化为 yyyy-mm-dd HH:mm:ss,这应该很容易,但我无法获得它可以工作。 需要解析的日期格式为:2012-
我正在尝试通过传递时间戳作为命令行参数来使用 Synapse 管道运行 Spark 作业。在与 Spark 作业相关的代码运行之前,synapse 正在将字符串命令行参数值从 ISO 格式 2019-
我试过下面的代码: String created_Date = "25-Nov-15 14:23:34"; SimpleDateFormat sdf = new SimpleDateFormat("d
我创建了一个函数,它以与原始格式不同的格式返回日期。基本上,我正在使用此 Select MonthSub('2014-04-10',2)# 语句进行测试,它应该返回2014-02,而不是 2014-0
我是一名优秀的程序员,十分优秀!