Java写Excel(不生成实体文件,写为流的形式)

java 写 Excel(不生成实体文件,写为流的形式)

public String exportReportExcel(String mediaCode, List<SimpleMediaResourceInfo> mediaResourceInfos) {
String scheduleURL = "";
// 1. 根据不同的媒介code查询对应的媒介细节内容
List<MediaContent> mediaContents = mediaContentMapper.selectByMediaCode(mediaCode);

// 2. 组装header
List<String> medias = new ArrayList<String>();
for (MediaContent mediaContent : mediaContents) {
medias.add(mediaContent.getAttrName());
}
String[] headers = new String[medias.size()];
headers = medias.toArray(headers);

// 3. 将内容写入对应的Excel
try {
ByteArrayOutputStream os = new ByteArrayOutputStream();
Workbook workbook = new XSSFWorkbook();

// 生成一个表格
Sheet sheet = workbook.createSheet();
sheet.setDefaultColumnWidth(13); // 调整列宽度

writeHeader(headers, workbook, sheet);
writeData(mediaResourceInfos, medias, sheet);// 遍历集合数据,产生数据行

workbook.write(os);

ByteArrayInputStream is = new ByteArrayInputStream(os.toByteArray());
scheduleURL = JdStorageService.getInstance().upload(is, (int) os.size(), "export.xls");

os.flush();
os.close();
is.close();
} catch (Exception e) {
e.printStackTrace();
}
return scheduleURL;
}

private void writeHeader(String[] headers, Workbook workbook, Sheet sheet) {
CellStyle style = workbook.createCellStyle();
XSSFFont font = (XSSFFont) workbook.createFont();
font.setBoldweight(HSSFFont.BOLDWEIGHT_BOLD);// 粗体显示
style.setFont(font);
style.setAlignment(HSSFCellStyle.ALIGN_CENTER); // 水平居中
style.setVerticalAlignment(HSSFCellStyle.VERTICAL_CENTER); // 垂直居中
// style.setFillForegroundColor(IndexedColors.TEAL.getIndex());
// //设置背景色
// style.setFillPattern(CellStyle.SOLID_FOREGROUND);

Row row0 = sheet.createRow(0);
row0.setHeightInPoints(18);
Cell showTimeTitle = row0.createCell((short) 0);
showTimeTitle.setCellValue("投放时间段(必填)");
Cell showTime = row0.createCell((short) 1);
showTime.setCellValue(" ");// TODO 时间问题
Cell remark = row0.createCell((short) 2);
remark.setCellValue("整个媒介投放的时间区间,按照从投放第一天到投放最后一天,如中间有间隔,需要用\",\"分开填写");

// 产生表格标题行
Row row = sheet.createRow(1);
row.setHeightInPoints(21);
for (int i = 0; i < headers.length; i++) {
Cell cell = row.createCell((short) i);
RichTextString text = new HSSFRichTextString(headers[i]);
cell.setCellValue(text.toString());
cell.setCellStyle(style);
}
}

private void writeData(List<SimpleMediaResourceInfo> mediaResourceInfos, List<String> medias, Sheet sheet) {
Row row;
if (!CollectionUtils.isEmpty(mediaResourceInfos)) {
int index = 2;
for (SimpleMediaResourceInfo rowData : mediaResourceInfos) {
row = sheet.createRow(index);
row.setHeightInPoints(21);

int cellIndex = 0;
if (!CollectionUtils.isEmpty(rowData.getMediaResourceTypes())
|| !CollectionUtils.isEmpty(rowData.getDetailContents())) {
for (String header : medias) {
for (SimpleMediaResourceType columnInfo : rowData.getMediaResourceTypes()) {
if (header.equals(columnInfo.getAttrName())) {
Cell cell = row.createCell((short) cellIndex);
cell.setCellValue(columnInfo.getAttrValue().toString());
}
}
for (SimpleMediaDetailContentItem columnInfo : rowData.getDetailContents()) {
if (header.equals(columnInfo.getAttrName())) {
Cell cell = row.createCell((short) cellIndex);
cell.setCellValue(columnInfo.getAttrValue().toString());
}
}
if (header.equals("时段")) {
Cell cell = row.createCell((short) cellIndex);
cell.setCellValue(ShowTimeHelper.transferFrom(rowData.getShowTimes()).toString());
}
cellIndex++;
}
index++;
}
}
}
}

转载于:https://www.cnblogs.com/wangxuemei/p/8418285.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
您好!要在Java后台以附件的方式发送Excel邮件而不生成实体文件,您可以使用Apache POI库来生成Excel文件,并使用JavaMail库发送邮件。以下是一个示例代码: ```java import java.io.ByteArrayOutputStream; import java.io.IOException; import javax.activation.DataHandler; import javax.activation.DataSource; import javax.mail.BodyPart; import javax.mail.Message; import javax.mail.MessagingException; import javax.mail.Multipart; import javax.mail.Session; import javax.mail.Transport; import javax.mail.internet.InternetAddress; import javax.mail.internet.MimeBodyPart; import javax.mail.internet.MimeMessage; import javax.mail.internet.MimeMultipart; import org.apache.poi.ss.usermodel.Workbook; import org.apache.poi.ss.usermodel.WorkbookFactory; public class ExcelEmailSender { public static void sendExcelEmail(Session session, String from, String to, String subject, Workbook workbook) throws MessagingException, IOException { Message message = new MimeMessage(session); message.setFrom(new InternetAddress(from)); message.setRecipients(Message.RecipientType.TO, InternetAddress.parse(to)); message.setSubject(subject); Multipart multipart = new MimeMultipart(); // 创建Excel文件的字节数组输出 ByteArrayOutputStream outputStream = new ByteArrayOutputStream(); workbook.write(outputStream); // 创建BodyPart并将Excel文件字节数组添加到BodyPart中 BodyPart bodyPart = new MimeBodyPart(); DataSource dataSource = new ByteArrayDataSource(outputStream.toByteArray(), "application/vnd.ms-excel"); bodyPart.setDataHandler(new DataHandler(dataSource)); bodyPart.setFileName("excel.xlsx"); // 将BodyPart添加到Multipart中 multipart.addBodyPart(bodyPart); // 设置邮件内容 message.setContent(multipart); // 发送邮件 Transport.send(message); } public static void main(String[] args) { String from = "your_email@example.com"; String to = "recipient_email@example.com"; String subject = "Excel Email"; // 使用Apache POI库创建Excel文件 Workbook workbook = WorkbookFactory.create(); // 在这里进行Excel文件的操作,例如创建工作表、添加数据等 // 设置JavaMail会话 Session session = Session.getInstance(System.getProperties()); try { sendExcelEmail(session, from, to, subject, workbook); System.out.println("Excel email sent successfully."); } catch (MessagingException | IOException e) { e.printStackTrace(); } finally { // 关闭工作簿 workbook.close(); } } } ``` 请确保您已将正确的发件人和收件人电子邮件地址替换到代码中的 `from` 和 `to` 变量中。此外,确保已添加Apache POI和JavaMail库到您的项目依赖中。 此代码将在Java后台创建一个Excel文件,并将其作为附件添加到电子邮件中,而不会生成实体文件。然后,使用JavaMail库发送邮件。 希望对您有所帮助!如有任何疑问,请随时提问。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值