首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >RubyXL:如何在工作表中添加多个数据单元格?

RubyXL:如何在工作表中添加多个数据单元格?
EN

Stack Overflow用户
提问于 2018-09-15 03:33:49
回答 3查看 1.1K关注 0票数 5

如何将整个单元格数组添加到一行?我有这样的东西->

代码语言:javascript
复制
w = RubyXL::Workbook.new
w.add_worksheet("Test")
test_sheet = w["Test"]
test_sheet.add_cell(0, 0, "abc") #this adds abc to row 0 and column 0

arr = ["hello","again","hi","there"]

有没有像这样的东西

代码语言:javascript
复制
test_sheet.add_row(a)

在哪里我可以将数组arr的所有内容放到测试工作表的一行中,而a的每个元素都在单独的单元格中?

EN

回答 3

Stack Overflow用户

发布于 2020-08-06 00:50:00

看起来没有官方的方法可以做到这一点。我们在项目中使用以下代码:

代码语言:javascript
复制
row_index = sheet.sheet_data.rows.size
arr.each_with_index do |value, index|
  sheet.add_cell(row_index, index, value)
end
票数 1
EN

Stack Overflow用户

发布于 2019-06-04 05:32:32

您可以使用:

代码语言:javascript
复制
worksheet.insert_row(1)

参考:https://www.rubydoc.info/gems/rubyXL/3.3.21#label-Insert+Row

票数 0
EN

Stack Overflow用户

发布于 2021-11-03 09:45:06

从我的代码库中添加多行数据的示例,而不是add_row继续向行中添加单元格希望这可能会有所帮助,虽然有许多其他方法可以在excel中写入,但遗留的rails应用程序仍然使用这个库:

代码语言:javascript
复制
workbook = RubyXL::Workbook.new
## First workbook
worksheet = workbook[0]
## Rename first workbook
worksheet.sheet_name = 'delayed_jobs_data'
header = ['JOB ID', 'PARENT ID', 'STATUS', 'PRIORITY', 'ATTEMPTS', 'JOB TYPE', 'HOST', 'USER', 'PROCESS', 'QUEUE', 'ITEM NUMBER', 'RUN AT', 'LOCKED AT', 'CREATED AT', 'COMPLETED AT']
header.each_with_index do |h, idx|
  worksheet.add_cell(0, idx, h)
end
worksheet.change_column_width(0, 10)
worksheet.change_column_width(1, 10)
worksheet.change_column_width(2, 10)
worksheet.change_column_width(3, 10)
worksheet.change_column_width(4, 10)
worksheet.change_column_width(5, 30)
worksheet.change_column_width(6, 20)
worksheet.change_column_width(7, 10)
worksheet.change_column_width(8, 30)
worksheet.change_column_width(9, 20)
worksheet.change_column_width(10, 10)
worksheet.change_column_width(11, 20)
worksheet.change_column_width(12, 20)
worksheet.change_column_width(13, 20)
worksheet.change_column_width(14, 20)
worksheet.change_row_fill(0, '808080')

## Now write the data
# check if the from data and to date present else archive the data of delayed jobs of the Time.now - 30 days current month
from = params[:from_date]
to = params[:to_date]
if !from.blank? && !to.blank?
  data = Model.where("created_at between ? and ?", from, to)
  file_name = "archiving_persited_jobs_from_#{from}_to_#{to}"

end

dest_file_path = Rails.root.join("public", "persisted_delayed_jobs", "#{file_name}.xlsm")

## After the data os written delete the data from database
data.each_with_index do |row, index|
  new_index = index += 1
  row_data = [row.id,
              (row.parent.id unless row.parent.blank?),
              row.status, row.priority, row.attempts, row.job_type, row.locked_by, row.user.full_name,
              (row.parent.job_type unless row.parent.blank?),
              row.queue, row&.item&.item_number,
              (row.run_at.to_datetime.in_time_zone(current_user.time_zone).strftime('%m/%d/%Y %H:%M') rescue row.run_at.strftime('%m/%d/%Y %H:%M')),
              (row.locked_at.to_datetime.in_time_zone(current_user.time_zone).strftime('%m/%d/%Y %H:%M') rescue row.locked_at.strftime('%m/%d/%Y %H:%M')),
              (row.created_at.to_datetime.in_time_zone(current_user.time_zone).strftime('%m/%d/%Y %H:%M') rescue row.created_at.strftime('%m/%d/%Y %H:%M')),
              (row&.completed_at&.to_datetime&.in_time_zone(current_user.time_zone)&.strftime('%m/%d/%Y %H:%M') rescue row&.completed_at&.strftime('%m/%d/%Y %H:%M')),
              (row&.failed_at&.to_datetime&.in_time_zone(current_user.time_zone)&.strftime('%m/%d/%Y %H:%M') rescue row&.failed_at&.strftime('%m/%d/%Y %H:%M')),
              (row.completed_at - row.created_at unless !row.created_at.blank? & !row.completed_at)
  ]
  # worksheet.insert_row(row_data)
  worksheet.add_cell(new_index, 0, row_data[0])
  worksheet.add_cell(new_index, 1, row_data[1])
  worksheet.add_cell(new_index, 2, row_data[2])
  worksheet.add_cell(new_index, 3, row_data[3])
  worksheet.add_cell(new_index, 4, row_data[4])
  worksheet.add_cell(new_index, 5, row_data[5])
  worksheet.add_cell(new_index, 6, row_data[6])
  worksheet.add_cell(new_index, 7, row_data[7])
  worksheet.add_cell(new_index, 8, row_data[8])
  worksheet.add_cell(new_index, 9, row_data[9])
  worksheet.add_cell(new_index, 10, row_data[10])
  worksheet.add_cell(new_index, 11, row_data[11])
  worksheet.add_cell(new_index, 12, row_data[12])
  worksheet.add_cell(new_index, 13, row_data[13])
  worksheet.add_cell(new_index, 14, row_data[14])
end

workbook.write(dest_file_path)
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/52338243

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档