Bip*_*o K 3 java google-sheets-api
您好:使用Google Spreadsheet API V4 on Java,我想获得column letter给定的column number. 示例:第 2列的列字母是B。
Google 电子表格 API 中是否已经提供了某种方法,或者是否有其他简单的方法可以执行此操作,或者我需要编写自己的转换?
尽管问题仍然是: Google Spreadsheet API V4 中是否有一个native way可以获取给定列号的列字母?
但是,future reference我在下面提供了一个collation以防有人需要实现自己的转换。
情况 1:根据给定的列号获取列字母
public void ColumnNumberToLetter() {
int inputColumnNumber = 49;
String outputColumnName = "";
int Base = 26;
String chars = "ABCDEFGHIJKLMNOPQRSTUVWXYZ";
int TempNumber = inputColumnNumber;
while (TempNumber > 0) {
int position = TempNumber % Base;
outputColumnName = (position == 0 ? 'Z' : chars.charAt(position > 0 ? position - 1 : 0)) + outputColumnName;
TempNumber = (TempNumber - 1) / Base;
}
System.out.println("ColumnNumberToLetter :" + inputColumnNumber + " = " + outputColumnName);
}
Run Code Online (Sandbox Code Playgroud)
情况 2:根据列字母获取列号
public void ColumnLetterToNumber() {
String inputColumnName = "AW";
int outputColumnNumber = 0;
if (inputColumnName == null || inputColumnName.length() == 0) {
throw new IllegalArgumentException("Input is not valid!");
}
int i = inputColumnName.length() - 1;
int t = 0;
while (i >= 0) {
char curr = inputColumnName.charAt(i);
outputColumnNumber = outputColumnNumber + (int) Math.pow(26, t) * (curr - 'A' + 1);
t++;
i--;
}
System.out.println("ColumnLetterToNumber : " + inputColumnName + " = " + outputColumnNumber);
}
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
2634 次 |
| 最近记录: |