java - 在 android.java 中读取 Excel 文件

标签 java android excel

我编写这段代码来读取一个 Excel 文件,我将它粘贴到 Assets 文件夹(我的文件名:book.xls)中以读取它。但是当我按下按钮显示文件时它不起作用并且不显示任何内容。 请帮我解决我的问题。 非常感谢。 这是我的代码:

package com.example.android.readingexcellfile;

import android.content.res.AssetManager;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.view.View;
import android.widget.TextView;

import java.io.InputStream;

import jxl.Cell;
import jxl.Sheet;
import jxl.Workbook;

public class MainActivity extends AppCompatActivity {

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
    }

    public void order (View v){

        try

        {
            AssetManager am=getAssets();
            InputStream is=am.open("book.xls");
            Workbook wb=Workbook.getWorkbook(is);
            Sheet s=wb.getSheet(0);
            int row=s.getRows();
            int col=s.getColumns();

            String xx="";
            for (int i=0;i<row;i++)
            {

                for(int c=0;i<col;c++)
                {
                    Cell z=s.getCell(c,i);
                    xx=xx+z.getContents();

                }

                xx=xx+"\n";
            }
            display(xx);
        }

        catch (Exception e){}




    }
    public void display (String value){

        TextView x=(TextView)findViewById(R.id.textView);
        x.setText(value);

    }


}

这是我的 xml:

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:id="@+id/activity_main"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:paddingBottom="@dimen/activity_vertical_margin"
    android:paddingLeft="@dimen/activity_horizontal_margin"
    android:paddingRight="@dimen/activity_horizontal_margin"
    android:paddingTop="@dimen/activity_vertical_margin"
    tools:context="com.example.android.readingexcellfile.MainActivity">

    <TextView
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="Hello World!"
        android:id="@+id/textView" />

    <Button
        android:text="Button"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_below="@+id/textView"
        android:layout_alignParentLeft="true"
        android:layout_alignParentStart="true"
        android:layout_marginLeft="28dp"
        android:layout_marginStart="28dp"
        android:layout_marginTop="69dp"
        android:onClick="order"
        android:id="@+id/button" />
</RelativeLayout>

最佳答案

display()方法永远不会被称为你的内部 for由于这一行,循环永远不会结束:

for(int c=0;i<col;c++)

将此更改为:

for(int c=0;c<col;c++)

(即检查'c'是<而不是col而不是'i')和TextView值按预期更改。

关于java - 在 android.java 中读取 Excel 文件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41523921/

相关文章:

java - 从两个 Date 对象计算持续时间的错误时间(以分钟为单位)

android Volley - Request.setSequence 没用?

excel - 如何在 Excel VBA 中使用 LIKE 运算符突出显示子字符串

android - android中的默认墓碑位置

android - 什么类型的 ssl 证书是可以接受的?

vba - 打开文件中的宏 如果你在开会,点击 "OK",如果没有,在excel中再次提及

sql-server - 基于 Excel 列列表筛选 SQL View 的 Power Query

java - 反转Java中的音频?

java - 非静态方法不能在静态上下文中引用

java - 同步 SynchronizedMap 的性能开销