繁体   English   中英

Aspose with RJB(Ruby Java Bridge)无法正常工作

[英]Aspose with RJB (Ruby Java Bridge) is not working

我有一个Java代码,可以通过aspose库打开一个excel模板(它可以完美运行):

import com.aspose.cells.*;
import java.io.*;

public class test
{
    public static void main(String[] args) throws Exception
    {
        System.setProperty("java.awt.headless", "true");
        FileInputStream fstream = new FileInputStream("/home/vmlellis/Testes/aspose-cells/template.xlsx");
        Workbook workbook = new Workbook(fstream);
        workbook.save("final.xlsx");
    }
}

在使用RJB (Ruby Java Bridge)在Ruby上运行此代码之后:

require 'rjb'

#RJM Loading
JARS = Dir.glob('./jars/*.jar').join(':')
print JARS
Rjb::load(JARS, ['-Xmx512M'])

system = Rjb::import('java.lang.System')
file_input = Rjb::import('java.io.File')
file_input_stream = Rjb::import('java.io.FileInputStream')
workbook = Rjb::import('com.aspose.cells.Workbook')

system.setProperty("java.awt.headless", "true")
file_path = "/home/vmlellis/Testes/aspose-cells/template.xlsx"
file = file_input.new(file_path)
fin = file_input_stream.new(file)

wb = workbook.new(fin)

我收到此错误:

test.rb:57:in `new': Can't find file: java.io.FileInputStream@693a317a. (FileNotFoundException)
    from aspose-test.rb:57:in `<main>'

为什么? 我运行相同的代码...但是在Ruby中不起作用! 我该如何解决?

更新:

文档中有一个初始化程序:Workbook(java.io.InputStreamstream)...但在RJB中不起作用。 (这怎么可能?)

您的程序应该可以运行,但是我找不到任何原因,所以我正在调查。

现在,替代方法。

方法1使用Workbook(String)构造函数而不是Workbook(FileInputStream)。 这在我最后完美无瑕。 示例代码是

require 'rjb'

#RJM Loading
JARS = Dir.glob('/home/saqib/cellslib/*.jar').join(':')
print JARS
Rjb::load(JARS, ['-Xmx512M'])

system = Rjb::import('java.lang.System')
workbook = Rjb::import('com.aspose.cells.Workbook')

system.setProperty("java.awt.headless", "true")
file_path = "/home/saqib/rjb/template.xlsx"
save_path = "/home/saqib/rjb/final.xlsx"

wb = workbook.new(file_path)
wb.save(save_path)

方法2编写一个新的Java类库。 在其中编写所有与Aspose.Cells相关的代码。 公开需要从Ruby(RJB)调用的非常简单和基本的方法。 为什么?

  • 用本机Java语言编写程序很容易。 如果使用RJB,则需要执行很多代码转换
  • 使用Java进行调试和测试很容易。
  • RJB的用法仅限于从您自己的Java库中调用方法。 RJB代码小而基本。

使用自己的库的类似示例创建一个新的Java项目,说“ cellstest”。 在其中添加一个新的公共类。

package cellstest;
import com.aspose.cells.Workbook;
public class AsposeCellsUtil 
{
    public String doSomeOpOnWorkbook(String inFile, String outFile)
    {
        String result = "";
        try
        {
            // Load the workbook
            Workbook wb = new Workbook(inFile);
            // Do some operation with this workbook
            // ..................
            // Save the workbook
            wb.save(outFile);
            // everything ok.
            result = "ok";
        }
        catch(Exception ex)
        {
            // Return the exception to calling program
            result = ex.toString();
        }
        return result;
    }
}

这样,为每个操作添加尽可能多的方法。 生成项目,并将“ cellstest.jar”复制到复制Aspose.Cells jar文件的文件夹中。 您可以从方法中返回String,然后在Ruby程序中检查返回值是否成功或错误代码。 Ruby程序现在就像

require 'rjb'

#RJM Loading
JARS = Dir.glob('/home/saqib/cellslib/*.jar').join(':')
print JARS
Rjb::load(JARS, ['-Xmx512M'])

system = Rjb::import('java.lang.System')
AsposeCellsUtil = Rjb::import('cellstest.AsposeCellsUtil')

system.setProperty("java.awt.headless", "true")
file_path = "/home/saqib/rjb/template.xlsx"
save_path = "/home/saqib/rjb/final.xlsx"

# initialize instance
asposeCellsUtil = AsposeCellsUtil.new()
# call methods
result = asposeCellsUtil.doSomeOpOnWorkbook(file_path, save_path)

puts result

PS。 我为Aspose工作,担任开发人员推广人员。

在Java代码中,您将文件名字符串传递给FileInputStream()构造函数:

FileInputStream fstream = new FileInputStream("/home/vmlellis/Testes/aspose-cells/template.xlsx");

在您的Ruby代码中,您传递了一个文件对象:

file = file_input.new(file_path)
fin = file_input_stream.new(file)

您是否尝试过执行与Java中相同的操作?

fin = file_input_stream.new(file_path)

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM