質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.35%
Java

Javaは、1995年にサン・マイクロシステムズが開発したプログラミング言語です。表記法はC言語に似ていますが、既存のプログラミング言語の短所を踏まえていちから設計されており、最初からオブジェクト指向性を備えてデザインされています。セキュリティ面が強力であることや、ネットワーク環境での利用に向いていることが特徴です。Javaで作られたソフトウェアは基本的にいかなるプラットフォームでも作動します。

Spring Boot

Spring Bootは、Javaのフレームワークの一つ。Springプロジェクトが提供する様々なフレームワークを統合した、アプリケーションを高速で開発するために設計されたフレームワークです。

Q&A

解決済

1回答

4354閲覧

ボタン押下でクラスを実行したい

kusogomitan

総合スコア17

Java

Javaは、1995年にサン・マイクロシステムズが開発したプログラミング言語です。表記法はC言語に似ていますが、既存のプログラミング言語の短所を踏まえていちから設計されており、最初からオブジェクト指向性を備えてデザインされています。セキュリティ面が強力であることや、ネットワーク環境での利用に向いていることが特徴です。Javaで作られたソフトウェアは基本的にいかなるプラットフォームでも作動します。

Spring Boot

Spring Bootは、Javaのフレームワークの一つ。Springプロジェクトが提供する様々なフレームワークを統合した、アプリケーションを高速で開発するために設計されたフレームワークです。

0グッド

0クリップ

投稿2020/11/05 06:27

編集2020/11/05 06:28

やりたいこと

HTML(thymeleaf)でボタンを表示し、押下した際にController → excelファイルを出力のように処理を行いたい。

下記のPOIreadを画面に表示したボタンが押下された際に実行するようにしたいのですが、調べてもわかりませんでした。
お力を貸していただけると嬉しいです。

ソース

POIread

1package graphics; 2import java.io.FileOutputStream; 3import java.io.IOException; 4import java.io.InputStream; 5import java.nio.file.Files; 6import java.nio.file.Path; 7import java.nio.file.Paths; 8 9import org.apache.poi.ss.usermodel.BorderStyle; 10import org.apache.poi.ss.usermodel.Cell; 11import org.apache.poi.ss.usermodel.CellStyle; 12import org.apache.poi.ss.usermodel.Row; 13import org.apache.poi.ss.usermodel.Sheet; 14import org.apache.poi.ss.usermodel.Workbook; 15import org.apache.poi.xssf.usermodel.XSSFWorkbook; 16 17public class POIread { 18 public static void main(String[] args) throws IOException { 19 Path tempPath = Paths.get("ファイルパス\編集用.xlsx"); 20 InputStream inSt = Files.newInputStream(tempPath); 21 Workbook workbook = new XSSFWorkbook(inSt); 22 FileOutputStream out = null; 23 24 Sheet sheet = workbook.getSheetAt(0); 25 Cell[][] cell; 26 cell = new Cell[100][4]; 27 Row[] row; 28 row = new Row[100]; 29 30 CellStyle style = workbook.createCellStyle(); 31 style.setBorderBottom(BorderStyle.THIN); 32 style.setBorderTop(BorderStyle.THIN); 33 style.setBorderRight(BorderStyle.THIN); 34 style.setBorderLeft(BorderStyle.THIN); 35 36 for(int i = 1; i <= row.length - 1; i++) { 37 38 row[i] = sheet.createRow(i); 39 40 cell[i][0] = row[i].createCell(0); 41 cell[i][1] = row[i].createCell(1); 42 cell[i][2] = row[i].createCell(2); 43 cell[i][3] = row[i].createCell(3); 44 45 cell[i][0].setCellValue("00" + i); 46 cell[i][0].setCellStyle(style); 47 cell[i][1].setCellValue("山田" + i + "太郎"); 48 cell[i][1].setCellStyle(style); 49 cell[i][2].setCellValue("ヤマダ" + i + "タロウ"); 50 cell[i][2].setCellStyle(style); 51 cell[i][3].setCellValue("東京都○○区○○ " + i +"-" + (i + 1) + "-" + (i + 2)); 52 cell[i][3].setCellStyle(style); 53 } 54 out = new FileOutputStream("ファイルパス\result.xlsx"); 55 56 workbook.write(out); 57 workbook.close(); 58 } 59 60} 61

掲載情報が少なくてすみません。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

plasticgrammer

2020/11/05 07:25

Controller との記載がありますが、何かフレームワークを導入/選定済みなのでしょうか? 想定しているWebサーバーなどありましたら追記をお願いします。
kusogomitan

2020/11/05 07:46

Springフレームワークを導入しています。 サーバーはApache Tomcat9.0です
guest

回答1

0

ベストアンサー

1.まず、Controllerとしての役割を持たせる為に「POIreadクラスはコントローラーですよー」と指定しなくてはいけません。そのためにアノテーションを付与します。

2.また、「ボタンを押した時」にexcelファイルに出力する場合は、ボタンを押下した際にrequestURLを設定することも必要です。こちらもアノテーションを付与 + htmlにてボタン押下時のRequestURLの設定が必要です。

3.Controllerには戻り値が必要ですのでmethodの形はvoidではなくStringが好ましいです。
ちなみに返す値はviewのファイル名です(今回で言うtest)。
※戻り値が必要な理由は、今回で言うボタン押下した後に"どの画面に遷移するか"を指定する必要があるためです。

java

1@Controller // ←1.追記 2public class POIread { 3 4   // ↓修正 5 @RequestMapping("/output") // ←2.追記 6 public String test2() throws IOException { 7 Path tempPath = Paths.get("ファイルパス\編集用.xlsx"); 8 InputStream inSt = Files.newInputStream(tempPath); 9 Workbook workbook = new XSSFWorkbook(inSt); 10 ... 11 12     return "test";

下記html名は「test.html」とします。

html

1<!DOCTYPE html> 2<html xmlns="http://www.w3.org/1999/xhtml" 3 xmlns:th="http://www.thymeleaf.org"> 4<head> 5<meta charset="UTF-8"> 6<title>thymeleaf</title> 7</head> 8<body> 9<!-- 2.追記 action-"/output"と指定することでボタン押下時javaのindexメソッドが呼び出されます! --> 10<form action="/output" method="post"> 11 <button type="submit" value="button">ボタン</button> 12<form> 13

処理の流れとしては
1.ボタン押下
2.@RequestMapping("/output")を付与しているメソッド(test2)が呼び出される。
3.test2メソッドの処理正常終了後、ブラウザ上にtest.htmlを再表示する。

といった感じになります。

投稿2020/11/06 16:11

yusn1230

総合スコア31

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.35%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問