如何用java读取ASCII码STL文件

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了如何用java读取ASCII码STL文件相关的知识,希望对你有一定的参考价值。

我刚学这,可以把整个代码给我吗???

参考技术A ASCII码格式STL文件逐行给出三角面片的几何信息,每一行以1个或2个关键字开头。在STL文件中的三角面片的信息单元facet是一个带矢量方向的三角面片,STL模型就是由一组这样的三角面片构成。在一个STL文件中,每一个facet由7行数据组成,第1行是三角面片指向实体外部的法向失量数据,第2行说明随后的第3,4,5行数据分别是三角面片的3个顶点信息,沿指向实体外部的法向矢量(第1行数据)方向逆时针排列。ASCII码格式的STL文件结构如下:
solid filename stl ∥ 文件路径及文件名
facet normal x y z ∥ 三角面片法向量的3个分量值
outer loop
vertex x y z ∥三角面片第一个顶点的坐标
vertex x y z ∥三角面片第二个顶点的坐标
vertex x y z ∥三角面片第三个顶点的坐标
endloop
endfacet ∥第一个三角面片定义完毕
………………………
………………………….
eadsolid fileame stl ∥整个文件结束

如何用java读取excel中的数据?下面的例子不能读出自己写的excel数据

public class POIreadExcel2003
public POIreadExcel2003()
try
// 读取要导出的excel文件
POIFSFileSystem fs = new POIFSFileSystem(new FileInputStream(
"e://workbook2.xls"));
HSSFWorkbook wb = new HSSFWorkbook(fs);
ExcelExtractor extractor = new ExcelExtractor(wb);
extractor.setFormulasNotResults(false);
extractor.setIncludeSheetNames(false);
// 工作表的序号
Sheet sheet1 = (Sheet) wb.getSheetAt(0);
// 开始遍历整个工作表
Iterator<Row> it = sheet1.rowIterator();
while (it.hasNext())
Row row = (Row) it.next();
Iterator<Cell> cit = row.cellIterator();
while (cit.hasNext())
// 输出数据
if (cit.next().getCellType() == Cell.CELL_TYPE_FORMULA)
Cell cell = cit.next();
FormulaEvaluator evaluator = wb.getCreationHelper()
.createFormulaEvaluator();
// 把公式行的数据计算出来
CellValue cellValue = evaluator.evaluate(cell);
System.out.println(cellValue.toString() + ",");
else
System.out.print(cit.next().toString() + ",");



catch (Exception e)
System.out.println("阅读失败...");


/**
* @param args
*/
public static void main(String[] args)
new POIreadExcel2003();

没用过这个POIFSFileSystem 操作excel

建议你用jcom来做 ,它虽然是日本人写的,但确实强大,而且速度快

如果你需要我可以给你个例子追问

需要,各种需要

参考技术A import java.io.FileInputStream;
import org.apache.poi.hssf.usermodel.HSSFCell;
import org.apache.poi.hssf.usermodel.HSSFRow;
import org.apache.poi.hssf.usermodel.HSSFSheet;
import org.apache.poi.hssf.usermodel.HSSFWorkbook;

public class ExcelTo
public static void main(String[] args)
String fileToBeRead = "g:\\Salary\\Salary.xls";
try
HSSFWorkbook workbook = new HSSFWorkbook(new FileInputStream(fileToBeRead)); // 创建对Excel工作簿文件的引用
HSSFSheet sheet = workbook.getSheet("员工表"); // 创建对工作表的引用
int rows = sheet.getPhysicalNumberOfRows();//获取表格的
for (int r = 0; r < rows; r++) //循环遍历表格的行
String value = "";
HSSFRow row = sheet.getRow(r); //获取单元格中指定的行对象
if (row != null)
int cells = row.getPhysicalNumberOfCells();//获取单元格中指定列对象
for (short c = 0; c < cells; c++) //循环遍历单元格中的列
HSSFCell cell = row.getCell((short) c); //获取指定单元格中的列
if (cell != null)
if (cell.getCellType() == HSSFCell.CELL_TYPE_STRING) //判断单元格的值是否为字符串类型
value += cell.getStringCellValue() + ",";
else if (cell.getCellType() == HSSFCell.CELL_TYPE_NUMERIC) //判断单元格的值是否为数字类型
value += cell.getNumericCellValue() + ",";
else if (cell.getCellType() == HSSFCell.CELL_TYPE_BOOLEAN) //判断单元格的值是否为布尔类型
value += cell.getStringCellValue() + ",";




String[] str = value.split(",");
System.out.println(value);

catch (Exception e)
e.printStackTrace();


本回答被提问者和网友采纳

以上是关于如何用java读取ASCII码STL文件的主要内容,如果未能解决你的问题,请参考以下文章

如何用C语言输出26个英文字母和其ascii码的对照表

如何用C语言输出26个英文字母和其ascii码的对照表

c中如何输出一个字符的ASCII码

字母转换ascii码

native2ascii转码工具的使用

如何用vtk读取stl模型获取点