RError.com

RError.com Logo RError.com Logo

RError.com Navigation

  • 主页

Mobile menu

Close
  • 主页
  • 系统&网络
    • 热门问题
    • 最新问题
    • 标签
  • Ubuntu
    • 热门问题
    • 最新问题
    • 标签
  • 帮助
主页 / user-242371

Бог's questions

Martin Hope
Бог
Asked: 2020-08-31 23:26:06 +0000 UTC

正确添加到词典

  • 0

有一个字典:

public Dictionary<int, OrderModel> x = new Dictionary<int, OrderModel>();

有一个 OrderModel :

public class OrderModel
{
    public int? Id { get; set; }
    public int OrderStatusId { get; set; }
    public int MenuId { get; set; }
    public ICollection<DishModel> Dishes { get; set; }
}

用户有一个产品列表。模型在这里:

public class DishModel
{
    public int ProvisionerId {get;set;}
}

每个产品都有自己的按钮。

单击此按钮时,将发生以下情况:

 //OrderModel этого товара отправляется в Dictionary, где происходит проверка
 public void method(DishModel dishModel){
  //Если элемент Dictionary по ключу dishModel.ProvisionerId не пустой, то засунь в него элемент типа OrderModel)
 if (x.TryGetValue(dishModel.ProvisionerId, out OrderModel checkForNull))
    {
      beforSerializeForProvisioners[dishModel.ProvisionerId] = OrderModel;
    }
  //Иначе если элемента Dictionary с таким ключом нет, то создай его.
 else
    {
   beforSerializeForProvisioners.Add(dishModel.ProvisionerId, OrderModel);
    }
}

我的问题是什么:

每个产品都有自己的供应商。

供应商 n 号。

你可以得到这个数额。

你需要这样做:

 Если товар имеет поставщика 1, то пусть он сохранится в Dictionary с ключом 1

 Иначе если товар имеет поставщика 2, то пусть он сохранится в Dictionary с ключом 2
 ...и т.д.

但问题是这样的:

 Когда пользователь нажал на товар, допустим с поставщиком 1, то он успешно создал Dictionary[1] и дал этому ключу значение.
 Если ещё нажать на ещё один товар этого же поставщика, то всё успешно повторится.

 Но если нажать на товар от другого поставщика, то происходит какая-то магия.
Он в Dictionary[1] добавляет этот товар от другого поставщика.
Он создает Dictionary[2] и туда также добавляет этот товар.

有2个解决方案。

1. Как-то правильно организовать добавление. Но у меня MVVM-паттерн, так что придется слишком многое выкладывать и адаптировать, чтобы была соблюдена конфиденциальность.
2. Перебрать весь Dictionary и его значения. 

我更倾向于第二种选择。

因此,您需要这样做:

Provisioners x = new Provisioners();
for(int i=0;i<x.Count();i++){
  foreach(DishModel y in Dictionary[x[i]]){
   if(y.ProvisionerId != Dictionary[x[i]].Dishes.ToList()[0].ProvisionerId) 
   {
      Dictionary[x[i]].Dishes.Remove(y);
    }
}

但是当 Remove();

VisualStudio2017 抱怨 Dictionary.Dishes 数组已被修改并且 foreach 已停止工作。

我明白为什么它被停产了。但是,用不同的提供商删除项目的最佳方法是什么?

字典中的键是供应商 ID。

c#
  • 1 个回答
  • 10 Views
Martin Hope
Бог
Asked: 2020-08-22 04:14:29 +0000 UTC

更新 TextArea 和 Label 值

  • 0

大量的互联网搜索。从来没有找到答案。我希望这篇文章能一劳永逸地为所有在谷歌上搜索这个问题的人解决这个问题。

问题的症结所在:

Есть TextArea
В него передаются строки следующим образом : TextArea.appendText(String text);
Но при повторном вызове кнопки, которая должна передать строки + значение из TextField
мы получаем : 
тот же самый список переменных + 
тот же самый список переменных + 
новая строка, 

но никак не "список переменных + новая строка".

在 Swing 和 JavaFX 中都遇到了这个问题。

未能解决。

建议的解决方案是:

TextArea.setText("");
 или
TextArea.setText(null);
 или
TextArea.clear();
 или
RunLater(); - многопоточность
 и прочее...

没有任何帮助。

对于那些不明白的人,我清楚地表明。

该程序在打开时会反映一组变量。

GO 按钮 - 解析左侧 TextField 中的值并将其放入数组中。它还应该更新 TextArea,即,将相同的数组传递给它,但使用一个新变量。

相反,值是重复的。

截图:

1)Состояние при запуске программы

在此处输入图像描述

2)Состояние после нажатия кнопки GO

在此处输入图像描述

这是 GO 按钮监听器

   @FXML
   private void updateMessages(ActionEvent event) {
    new ListMessages();

    for (int i = 0; i < ListMessages.text.size(); i++) {
        areaForMessages.appendText(ListMessages.text.get(i) + "\n");      
    }
}

如何清除 TextArea?

java
  • 1 个回答
  • 10 Views
Martin Hope
Бог
Asked: 2020-06-26 03:42:05 +0000 UTC

Java 中的 AutoHotKey

  • 3

第 n 次使用 AutoHotKey 程序,当我按下“w”按钮时,我在游戏中执行某​​个键序列(换句话说,“宏”),问题如下:

如何在 Java 中实现类似的东西?我看了 java.awt.Robot 类,做了一个简单的应用程序,但问题是为了读取击键,你需要用代码激活应用程序窗口,但你不能就这样改变它。

有人解决了这个问题吗?如果是这样,如何。如果不是,那么去哪里挖?

java
  • 1 个回答
  • 10 Views
Martin Hope
Бог
Asked: 2020-05-15 16:11:50 +0000 UTC

创建新的 Excel 工作表 (Java) (Apache POI)

  • 0

从 JTable 写入 Excel 时,会不断创建新的 xls 文件,而不是创建新工作表。例如 :

excel电子表格中有5张纸。

该程序基于该表构建一个 JTable。

并且有必要在 JTable 中更改时,将所有数据保存回 Excel 表。

我的代码中发生的事情是每张纸都在一个新窗口中打开。但是按xls文件中的保存键,所有工作表都被擦除,创建当前工作表并保存数据。并且有必要覆盖其中一张现有工作表中的数据。

所有代码都适用于 Apache POI,但这段代码适用于 JXL

WritableWorkbook workbook1 = Workbook.createWorkbook(new File("C:\\result.xls"));
                WritableSheet sheet1 = workbook1.createSheet(list, listnum);
                TableModel model = table.getModel();

                for (int i = 0; i < model.getColumnCount(); i++) {
                    Label column = new Label(i, 0, model.getColumnName(i));
                    sheet1.addCell(column);
                }
                int j = 0;
                for (int i = 0; i < model.getRowCount(); i++) {
                    for (j = 0; j < model.getColumnCount(); j++) {
                        Label row = new Label(j, i + 1,
                                model.getValueAt(i, j).toString());
                        sheet1.addCell(row);
                    }
                }
                workbook1.write();
                workbook1.close();

如何修复将其从 jxl 转换为 apache poi 的代码?

在第一行中,您需要更改的不是创建新书,而是阅读现有的书。

java
  • 1 个回答
  • 10 Views
Martin Hope
Бог
Asked: 2020-04-27 18:31:22 +0000 UTC

将新行添加到按钮上的 JTable (Java) (Swing)

  • 1

是的,一个新手问题。不用嘲笑。

我有一个 JTable在此处输入图像描述

在红色区域(这是用油漆绘制的)需要添加三个按钮:

  1. 添加 - 按此按钮应出现一个新行。
  2. 保存 - 我将自己绑定事件侦听器,但你需要这样做,以便如果某处有空单元格,按下它会抛出对话框“有空字段!检查所有字段!”,以及保存位置,等等 我会自己做。这并不难。
  3. 删除 - 删除选定的行。

我试过浏览有关展示位置管理器和添加按钮的教程,但我似乎找不到我要找的东西。

表模型为:

    TableModel tableModel = new DefaultTableModel(data, columnNames);
    JTable table = new JTable(tableModel);
    table.setModel(tableModel);
    DefaultTableModel model = (DefaultTableModel) table.getModel();

    table.setModel(model);

以下是删除一行的方法:

     int sel = 0; // или номер строки или getSelestedRow
     model.removeRow(sel); // удаление выбранной строки

我只是在网上搜索了各种代码创建了一个表格和一个程序,但是在这部分我无法添加添加按钮。

java
  • 1 个回答
  • 10 Views
Martin Hope
Бог
Asked: 2020-04-26 16:58:57 +0000 UTC

将 Excel 表传输到 Swing Java 的正确算法

  • 0

有一个 excel 表格,其中有 n 个工作表,m 个行数,z 个列数。

它需要移植到 Java Swing JTable。

我没有使用 swing,但我加入了一个近似算法。纠正错误的地方:

int list = парсим кол-во листов;
int a=0;
int b=0;
int stolb=0;
int strok=0;
for(int i=0;i<list;i++){
stolb = количество ненулевых стобцов текущего листа;
strok =  количество ненулевых строк;
создай новую таблицу размером (stolb;strok);
для ячеек JTable(a;b) = парсируй ячейки из excel(a;b);
}

我的算法正确吗?

谁能将算法转化为工作方法?

为了解析 Excel,使用了 Apache POI 库。

从评论来看,我开始尝试实施它,我来到了这个:

我有一个包含列名的数组

Holod.Header

使用二维数组的循环,您可以像这样从我需要的Excel表格中解析数据

Holod.sheet.getRow(i).getCell(j)

数据类型是

HSSFCell

实际代码本身:

package kursach;

import java.awt.Dimension;

import javax.swing.JFrame;
import javax.swing.JScrollPane;
import javax.swing.JTable;
import tovars.Holod;

public class start extends JFrame {

 public static void createGUI() {
      JFrame frame = new JFrame("Test frame");
      frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
      String [] columnNames = new String[Holod.Header.size()];
      for (int i = 0; i < Holod.Header.size(); i++) {
        columnNames[i]=Holod.Header.get(i).toString();
      }

      String [][] data = new String [Holod.countStrok][Holod.countStolbc];
      for (int j = 1; j < Holod.countStolbc; j++) {
        for (int i = 1; i < Holod.countStrok; i++) {
          data[j][i]= Holod.sheet.getRow(i).getCell(j).toString();
         }
       }

      JTable table = new JTable(data, columnNames);

       JScrollPane scrollPane = new JScrollPane(table);

       frame.getContentPane().add(scrollPane);
       frame.setPreferredSize(new Dimension(450, 200));
       frame.pack();
       frame.setLocationRelativeTo(null);
       frame.setVisible(true);
  }

 public static void main(String[] args) {
      javax.swing.SwingUtilities.invokeLater(new Runnable() {
           public void run() {
                JFrame.setDefaultLookAndFeelDecorated(true);
                createGUI();
           }
      });
  }
  }

意思是:

我累了。我似乎无法正确创建表格

  Exception in thread "AWT-EventQueue-0" java.lang.NullPointerException

等等等等。看看有什么问题。坐了一个小时了,两个阵都做不出来。该死。

一个小时以后 :

    int noOfColumns = sheet.getRow(0).getPhysicalNumberOfCells();
    int noOfRows = sheet.getPhysicalNumberOfRows();

    HSSFCell[] columnNames = new HSSFCell[noOfColumns];
    for (int i = 0; i < columnNames.length; i++) {
        columnNames[i] = sheet.getRow(0).getCell(i);
    }

    HSSFCell[][] data = new HSSFCell[noOfColumns][noOfRows];
    for (int j = 1; j < noOfColumns + 1; j++) {
        for (int i = 1; i < noOfRows + 1; i++) {
            data[j][i] = sheet.getRow(j).getCell(i);
            System.out.println(data[j][i]);
        }
    }

起飞:

  Exception in thread "AWT-EventQueue-0" java.lang.ArrayIndexOutOfBoundsException: 11
java
  • 1 个回答
  • 10 Views
Martin Hope
Бог
Asked: 2020-04-22 20:42:05 +0000 UTC

获取 JList 的选定元素(Java)

  • 0

有这样一个面板 JList :

在此处输入图像描述

有必要根据从 JList 中选择的元素,在 JPanel 中反映一些文本。

如果用户点击任何其他元素,则会出现另一个文本。

我听说过有关 getSelectedValue() 的信息,但我不知道将其插入何处。

你能帮我实现这种方法吗?

java
  • 1 个回答
  • 10 Views
Martin Hope
Бог
Asked: 2020-04-14 17:35:33 +0000 UTC

与在线商店合作的程序 (Java)

  • 1

有 :

  • .xls中的剩余文件,- 它包含产品文章、名称、价格。
  • OpenCart 上的站点(不适用于此类构造函数,因为我只是在纯 html 上从头开始编写站点)。

网站上大约有 1000 种产品,每周您需要从库存文件中更新网站上的文章。

我试图在 Java 中实现类似的代码算法:

  • 通过Apache POI解析 .xls
  • 将文章和名称保存在数组中
  • 我们遍历数组并在站点管理页面上查找具有相同名称的产品。
  • 我们使用 jsoup 解析它的文章,- 如果文章不同,那么我们从剩余文件中取出文章并将其分配给该产品。我们检查。
  • 我们进一步遍历数组其余部分的循环。

有没有更合适的解决方案?

找到这个 API:

https://www.opencart.com/index.php?route=marketplace/extension/info&extension_id=20043

http://docs.opencart.com/system/users/api/

使用此引擎和产品的算法应该是什么?

java
  • 1 个回答
  • 10 Views

Sidebar

Stats

  • 问题 10021
  • Answers 30001
  • 最佳答案 8000
  • 用户 6900
  • 常问
  • 回答
  • Marko Smith

    我看不懂措辞

    • 1 个回答
  • Marko Smith

    请求的模块“del”不提供名为“default”的导出

    • 3 个回答
  • Marko Smith

    "!+tab" 在 HTML 的 vs 代码中不起作用

    • 5 个回答
  • Marko Smith

    我正在尝试解决“猜词”的问题。Python

    • 2 个回答
  • Marko Smith

    可以使用哪些命令将当前指针移动到指定的提交而不更改工作目录中的文件?

    • 1 个回答
  • Marko Smith

    Python解析野莓

    • 1 个回答
  • Marko Smith

    问题:“警告:检查最新版本的 pip 时出错。”

    • 2 个回答
  • Marko Smith

    帮助编写一个用值填充变量的循环。解决这个问题

    • 2 个回答
  • Marko Smith

    尽管依赖数组为空,但在渲染上调用了 2 次 useEffect

    • 2 个回答
  • Marko Smith

    数据不通过 Telegram.WebApp.sendData 发送

    • 1 个回答
  • Martin Hope
    Alexandr_TT 2020年新年大赛! 2020-12-20 18:20:21 +0000 UTC
  • Martin Hope
    Alexandr_TT 圣诞树动画 2020-12-23 00:38:08 +0000 UTC
  • Martin Hope
    Air 究竟是什么标识了网站访问者? 2020-11-03 15:49:20 +0000 UTC
  • Martin Hope
    Qwertiy 号码显示 9223372036854775807 2020-07-11 18:16:49 +0000 UTC
  • Martin Hope
    user216109 如何为黑客设下陷阱,或充分击退攻击? 2020-05-10 02:22:52 +0000 UTC
  • Martin Hope
    Qwertiy 并变成3个无穷大 2020-11-06 07:15:57 +0000 UTC
  • Martin Hope
    koks_rs 什么是样板代码? 2020-10-27 15:43:19 +0000 UTC
  • Martin Hope
    Sirop4ik 向 git 提交发布的正确方法是什么? 2020-10-05 00:02:00 +0000 UTC
  • Martin Hope
    faoxis 为什么在这么多示例中函数都称为 foo? 2020-08-15 04:42:49 +0000 UTC
  • Martin Hope
    Pavel Mayorov 如何从事件或回调函数中返回值?或者至少等他们完成。 2020-08-11 16:49:28 +0000 UTC

热门标签

javascript python java php c# c++ html android jquery mysql

Explore

  • 主页
  • 问题
    • 热门问题
    • 最新问题
  • 标签
  • 帮助

Footer

RError.com

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

帮助

© 2023 RError.com All Rights Reserve   沪ICP备12040472号-5