Ruby 如果用 spreadsheet_architect 导出这样的表格

stephen · 2024年12月09日 · 最后由 martin91 回复于 2025年01月13日 · 422 次阅读

如果用 spreadsheet_architect 导出这样的表格

合并单元格?

https://github.com/westonganger/spreadsheet_architect/blob/master/test/unit/xlsx/general_test.rb#L52-L56

merges: [
  {range: "A1:C1"},
  {range: {rows: 2, columns: :all}},
  {range: {rows: (3..4), columns: (0..3)}}
],

分享个古早的技巧,使用 XML Spreadsheet,写起来跟 HTML 模板类似,可读性好,也可以支持定制单元格合并以及样式等,但不确定最新版 Office 还有没有保持兼容。

<?xml version="1.0"?>
<Workbook xmlns="urn:schemas-microsoft-com:office:spreadsheet"
  xmlns:o="urn:schemas-microsoft-com:office:office"
  xmlns:x="urn:schemas-microsoft-com:office:excel"
  xmlns:ss="urn:schemas-microsoft-com:office:spreadsheet"
  xmlns:html="http://www.w3.org/TR/REC-html40">
  <Worksheet ss:Name="Sheet1">
    <Table>
      <Row>
        <Cell><Data ss:Type="String">ID</Data></Cell>
        <Cell><Data ss:Type="String">Name</Data></Cell>
        <Cell><Data ss:Type="String">Release Date</Data></Cell>
        <Cell><Data ss:Type="String">Price</Data></Cell>
      </Row>
    <% @products.each do |product| %>
      <Row>
        <Cell><Data ss:Type="Number"><%= product.id %></Data></Cell>
        <Cell><Data ss:Type="String"><%= product.name %></Data></Cell>
        <Cell><Data ss:Type="String"><%= product.released_on %></Data></Cell>
        <Cell><Data ss:Type="Number"><%= product.price %></Data></Cell>
      </Row>
    <% end %>
    </Table>
  </Worksheet>
</Workbook>

RailsCast 上有教程,我几年前还在 Shopee 用这个东西实现比较复杂的 Excel 样式。 http://railscasts.com/episodes/362-exporting-csv-and-excel?view=asciicast https://learn.microsoft.com/en-us/previous-versions/office/developer/office-xp/aa140066v=office.10)?redirectedfrom=MSDN(

martin91 回复

最后还是选择了这种方式,的确比较直观

martin91 回复

Good idea 学到了

martin91 回复

这个好,学习了。

martin91 回复

学到了,之前做过一个单据导出用的是 https://github.com/sail-sail/ejsExcel 很类似的思路

@martin91 有没有遇到按这种方法,导出的 xls 文档,手机打不开。打开也是代码状态

stephen 回复

没有留意,当时我们的用户都是笔记本电脑。手机上估计是没有兼容这种格式的,毕竟这种格式很老了,手机 APP 要轻量,没有兼容老版本吧。

需要 登录 后方可回复, 如果你还没有账号请 注册新账号