征服.刘华强 2013-04-28 15:53
浏览 431
已采纳

请教 Aspose.Cells for Java 自定义excel模板问题

现在定义模板如下

[img]http://dl.iteye.com/upload/attachment/0083/8208/f1152188-542b-3409-85b5-69f2a50ebca0.jpg[/img]

现在贴出关键代码
[code="java"]
Workbook wb = new Workbook(template_file_path);
WorkbookDesigner designer = new WorkbookDesigner();
designer.setWorkbook(wb);
/* Map person = new HashMap();
person.put("id", "id");
person.put("name", "name");*/
Person person = new Person("1" , "jack");
designer.setDataSource("Person", person);
designer.process(true);
return wb;
[/code]

第一个问题????

现在的问题是设置Person person = new Person("1" , "jack");实体类可以正确导出excel
但是设置hashMap 就不能导出 有时报表比价复杂 用hashMap更灵活些 有什么办法解决

第二个问题????

[code="java"]
public class DataTable implements ICellsDataTable
{
private ArrayList list = null;
private int index;

public DataTable()
{
    list = new ArrayList<Person>();
    for(int i = 0; i < 10; i++)
    {
        Person person = new Person("" + i, "Person" + i);
        list.add(person);
    }
    index = -1;
}

public String[] getColumns()
{
    return new String[]
    {
            "id", "name"
    };
}

public int getCount()
{
    return this.list.size();
}

public void beforeFirst()
{
    index = -1;
}

public Object get(int columnIndex)
{
    if(index < 0 || index >= this.getCount())
    {
        return null;
    }
    Person person = this.list.get(index);
    switch (columnIndex)
    {
        case 0:
            return person.getId();
        case 1:
            return person.getName();
        default:
            return null;
    }
}

public boolean next()
{
    index += 1;
    if(index >= this.getCount())
    {
        return false;
    }
    return true;
}

//这个方法为什么不执行呢 执行的是public Object get(int columnIndex)
// 我希望执行public Object get(String columnName)这个方法,这样我就可以写一个通用的方法
/**
* Returns the value of the designated column in the current row.
*
* @param columnName
* the property name of the POJO.
* @return the value of the designated column in the current row.
*/
public Object get(String columnName)
{
Person person = this.list.get(index);
if(columnName.equals("id"))
{
return person.getId();
}
if(columnName.equals("name"))
{
return person.getName();
}

    return null;
}

}
[/code]

最后一个问题???
是如何在模板中定义图片 然后填充进去,像那种个人简历的模板

  • 写回答

2条回答 默认 最新

  • zyn010101 2013-04-28 16:12
    关注

    第一个问题:你可以放map里面,自己写一个工具类,利用反射把map的value放入对象的对应属性中,返回对象,第二个问题:仔细检查代码,打断点跟一下;第三个问题:给图片占用的单元格定义一个标志,后台判断,如果符合条件:插入图片:[url]http://wysunning.iteye.com/blog/570238[/url]

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
  • clxy大叔 2013-04-28 17:11
    关注

    前两个问题应该是一个问题,即不支持map形的数据源。
    但是支持list,哈。比较怪的框架。

    评论
查看更多回答(1条)

报告相同问题?

悬赏问题

  • ¥15 组件库引入并使用在若依框架未展示
  • ¥149 关于#使用python 的Flash Echarts+ajax+mysql动态数据实现饼图#的问题,请各位专家解答!
  • ¥15 RichTextBox中追加文本时报错
  • ¥15 关于c语言的学习问题
  • ¥15 activity升级到flowable工作流act_ge_bytearray的草稿json数据复制到act_de_model 的model_editor_json的脚本
  • ¥15 cvi使用CreateThread创建线程时,出现存储空间不足无法处理此命令的错误
  • ¥15 求苹果推信imessage批量推信技术
  • ¥15 ubuntu 22.04 系统盘空间不足。隐藏的docker空间占用?(相关搜索:移动硬盘|管理系统)
  • ¥15 c++ word自动化,为什么可用接口是空的?
  • ¥15 Matlab计算100000*100000的矩阵运算问题: