if等式为什么没有结果

yzyz0812 2014-09-07 08:48:00
这是我的代码

Sheet[] sheets = wb_read.getSheets();// 获取所有的sheet
for (x = 0; x < sheets.length; x++) {
Sheet s = wb_read.getSheet(x);// 获取sheet
}
System.out.print("---------------");
System.out.print(user_text);
Sheet s = wb_read.getSheet(0);// 获取sheet
rows = s.getRows();// 总行
cols = s.getColumns();// 总列
String[][] str=new String[rows][cols] ;
System.out.print("-------------");
System.out.print("\n");
for (int i = 0; i < rows; i++) {
for (int j = 0; j < cols; j++) {
str[i][j] = (s.getCell(j, i)).getContents();// getCell(Col,Row)获得单元格的值
System.out.print(str[i][j] + "\t");
}
System.out.print("\n");
}
System.out.print("-------------");
System.out.print("\n");
for(int i=4;i<rows;i++)
{System.out.print("$"+str[i][0]);
System.out.print("\n");
System.out.print("#"+user_text);
if(str[i][0]==user_text)
{
System.out.print("@"+str[i][0]);
System.out.print(user_text);
z=i;
}
}
System.out.print("z="+z);
num_c= s.getCell(4, z).getContents();//商户编码
我想用jxl导入excel,根据输入的商户编码(uesr_text),输出表格中的一系列信息,其他部分都正常,但是为什么if没有结果出来,
if(str[i][0]==user_text)
{
System.out.print("@"+str[i][0]);
System.out.print(user_text);
z=i;
}

...全文
185 3 打赏 收藏 转发到动态 举报
写回复
用AI写文章
3 条回复
切换为时间正序
请发表友善的回复…
发表回复
yzyz0812 2014-09-09
  • 打赏
  • 举报
回复
确实是用equals,已经解决了,结贴
yoyo4988 2014-09-07
  • 打赏
  • 举报
回复
楼上说的对,字符串比较用equals 不用== 楼主可以用equals 试试
Kenney_Qin 2014-09-07
  • 打赏
  • 举报
回复
我看你的意思是想比较字符串str[i][0]和user_text是否一样对不?在java中比较字符串的内容是否一样,不能用”==“,如果写成”==“,是在比较两个字符串的地址是不是一样。改成 if(str[i][0].equals(user_text)) 就好了,希望能帮到你~

62,614

社区成员

发帖
与我相关
我的任务
社区描述
Java 2 Standard Edition
社区管理员
  • Java SE
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧