Excel Sheet Column Title 把整数转换为大写字母的组合

Given a positive integer, return its corresponding column title as appear in an Excel sheet.

For example:

    1 -> A
    2 -> B
    3 -> C
    ...
    26 -> Z
    27 -> AA
    28 -> AB 

/*String s="ABC"; 
System.out.println(s.charAt(2)-'A');//char可以自动转换为Int类型。再进行运算 
System.out.println('A');*/
单引号引的数据 是char类型的
双引号引的数据 是String类型的
转java中String和int以及char相加的时候系统自动调用的int和char的包装类的toString方法,将int型和char型转换成了String型,还要注意的一点是,String类型(说对象更好)都是不可变的

String 类型和StringBuffer的主要性能区别:String是不可变的对象, 因此在每次对String 类型进行改变的时候,都会生成一个新的 String 对象,然后将指针指向新的 String 对象,所以经常改变内容的字符串最好不要用 String ,因为每次生成对象都会对系统性能产生影响,特别当内存中无引用对象多了以后, JVM 的 GC 就会开始工作,性能就会降低。

使用 StringBuffer 类时,每次都会对 StringBuffer 对象本身进行操作,而不是生成新的对象并改变对象引用。所以多数情况下推荐使用 StringBuffer ,特别是字符串对象经常改变的情况下。

基本原则:如果要操作少量的数据,用String ;单线程操作大量数据,用StringBuilder ;多线程操作大量数据,用StringBuffer。

public class Solution {
    public String convertToTitle(int n) {
        String s=new String();
        String res=new String();
        char c;
        while(n!=0){
            c=(char)((n-1)%26+'A');//把asicc码转化为字符,其他的理解只是数学上的理解了
            s+=c; //你看,是可以直接加上c的哦
            n=(n%26==0)?(n/26-1):(n/26);
        } //求出来的字符串跟题目要求恰好是相反的
        for(int i=s.length()-1;i>=0;i--){ //这个for语句实现字符串的反转
            c=(char)s.charAt(i);
            res+=c;
        }
        return res;
    }
}

 
下边的写法是用了StringBuilder进行反转,因为StringBuilder自带反转方法
public class Solution {
    public String convertToTitle(int n) {
        StringBuilder s=new StringBuilder();
        char c;
        while(n!=0){
            c=(char)((n-1)%26+'A');
            s.append(c); //它不能用+,只能用append方法
            n=(n%26==0)?(n/26-1):(n/26);
        }
        return s.reverse().toString();
    }
}


StringBuffer也是可以的
public class Solution {
    public String convertToTitle(int n) {
        StringBuffer s=new StringBuffer();
        char c;
        while(n!=0){
            c=(char)((n-1)%26+'A');
            s.append(c);
            n=(n%26==0)?(n/26-1):(n/26);
        }
        return s.reverse().toString(); //使用StringBuffer,如果想转成String类型,可以调用StringBuffer的toString()方法。
    }
}


你可以使用Apache POI库来读取Excel Sheet并将其转换为Java类。下面是一个简单的示例代码: ```java import java.io.File; import java.io.FileInputStream; import java.io.IOException; import java.util.ArrayList; import java.util.Iterator; import org.apache.poi.ss.usermodel.Cell; import org.apache.poi.ss.usermodel.Row; import org.apache.poi.ss.usermodel.Sheet; import org.apache.poi.ss.usermodel.Workbook; import org.apache.poi.xssf.usermodel.XSSFWorkbook; public class ExcelReader { public static void main(String[] args) throws IOException { String excelFilePath = "path/to/excel/file.xlsx"; FileInputStream inputStream = new FileInputStream(new File(excelFilePath)); Workbook workbook = new XSSFWorkbook(inputStream); Sheet sheet = workbook.getSheet("Sheet1"); Iterator<Row> iterator = sheet.iterator(); ArrayList<Employee> employees = new ArrayList<>(); while (iterator.hasNext()) { Row nextRow = iterator.next(); Iterator<Cell> cellIterator = nextRow.cellIterator(); Employee employee = new Employee(); while (cellIterator.hasNext()) { Cell nextCell = cellIterator.next(); int columnIndex = nextCell.getColumnIndex(); switch (columnIndex) { case 0: employee.setId((int) nextCell.getNumericCellValue()); break; case 1: employee.setName(nextCell.getStringCellValue()); break; case 2: employee.setAge((int) nextCell.getNumericCellValue()); break; } } employees.add(employee); } workbook.close(); inputStream.close(); // Do something with the employees list } } class Employee { private int id; private String name; private int age; public int getId() { return id; } public void setId(int id) { this.id = id; } public String getName() { return name; } public void setName(String name) { this.name = name; } public int getAge() { return age; } public void setAge(int age) { this.age = age; } } ``` 在这个示例中,我们读取了名为“Sheet1”的Excel Sheet,并将其转换为一个包含Employee对象的ArrayList。你可以根据需要修改代码来适应你的Excel Sheet和Java类。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值