一是标准的输出输入方式
比如新建一个磁盘文件c:\a.txt,
将键盘输入的一字符串写到文件中:
FILE *ft
char str[50]
ft=fopen("c:\\a.txt","w+")
printf("输入一个字符串:")
scanf("%s",str)
fputs(str,ft)
fclose(ft)
//重新打开这个文件并读出字符串,显示在屏幕上
ft=fopen("c:\\a.txt","rt")
fgets(str,50,ft)
fclose(ft)
printf("%s",str)
二是低级输入输出方式
仍如上例:
int hd
char str[50]
printf("输入一个字符串:")
scanf("%s",str)
hd=open("c:\\a.txt",O_CREAT|O_TEXT|O_WRONLY)
write(hd,str,strlen(str))
close(hd)
//重新打开这个文件并读出字符串,显示在屏幕上
hd=open("c:\\a.txt",O_TEXT|O_RDONLY)
read(hd,str,50)
close(hd)
printf("%s",str)
空指针异常! 上传文件不是这样的, 文件名和文件都在请求体中, 一定要用POST还要l加一个属性 enctype="multipart/form-data", 进去了才解析请求体才能得到的
你写 <file name="filename" /> 你在服务端 request.getParameter("filename") 是得不到的
因为这些数据和 上传的文件流都封装在请求体中, 要解析的
你如果只要文件名: 可以这样
<file name="file" />
<hidden type="text" name="filename" />
用JS/或者JQUERY在提交时赋值才行
不明白为啥指定json,我的建议是:1、STRUTS文件标签选择并上传EXCEL文件,示例代码:
<html:form action="/uploadExcelFile/UploadExcelFileAction.go" enctype="multipart/form-data" method="post" onsubmit="return confirm_save()">
<table border="0" cellpadding="0" cellspacing="5" align="center" style="margin:50">
<tr>
<td align="right" nowrap >请选择Excel文件(.<%=excelType%>):</td>
<td align="right" colspan="3" valign="middle" nowrap ><html:file property="aircraftExcel" size="200" style="width:400height:25" value=""></html:file></td>
</tr><tr>
<td></td>
<td align="right">Excel文件中标题(表头)占行:</td>
<td align="left"><input name="topicRow" value="0" style="width:50" onKeyUp="value=value.replace(/[\D]/g,'')"/></td>
<TD align="right" nowrap title="上传"><html:submit value="开始更新" style="height:25width:70"></html:submit></TD>
</tr>
</table>
</html:form>
2、UploadExcelFileAction接收、写入后台指定目录(局部代码)
FileOutputStream fos = null
try {
//得到文件数据(数组)
byte[] fileDate = ff.getFileData()
//得到服务器硬盘文件夹的绝对路径
ServletContext application = this.getServlet().getServletContext()
String realPath = application.getRealPath("/")
if(excelType==null||excelType.equals("xlsx"))//默认生成2007以后版本格式
fos = new FileOutputStream(realPath+"aircraftExcelTable.xlsx")
else
fos = new FileOutputStream(realPath+"aircraftExcelTable.xls")
fos.write(fileDate)
fos.close()
if(excelType==null||excelType.equals("xlsx"))//默认生成2007以后版本格式
num=ReadExcelSaveToDB.ReadAndSaveNew(realPath+"aircraftExcelTable.xlsx",topicNumber)
else
num=ReadExcelSaveToDB.ReadAndSave(realPath+"aircraftExcelTable.xls",topicNumber)
if(num==-1){
session.setAttribute("forwardPage", currentPage)
session.setAttribute("prompt", "文件传输失败或无法连接数据库!")
return mapping.findForward("promptpage")
}else if(num==-2){
session.setAttribute("forwardPage", currentPage)
session.setAttribute("prompt", "Excel文件大于1000条或不能识别!重新制作Excel文件。")
return mapping.findForward("promptpage")
}else if(num==-3){
session.setAttribute("forwardPage", currentPage)
session.setAttribute("prompt", "Excel文件中包含非法字符(非数字),请修正后重试。")
return mapping.findForward("promptpage")
}
} catch (FileNotFoundException e) {
e.printStackTrace()
} catch (IOException e) {
e.printStackTrace()
}finally{
try {
fos.close()
} catch (IOException e) {
e.printStackTrace()
}
}
3、解析读取表数据(POI)并存入数据库(局部代码)
public static int ReadAndSave(String path,String topicNumber){
try {
File file=new File(path)
FileInputStream fs=new FileInputStream(file)
@SuppressWarnings("resource")
HSSFWorkbook workbook=new HSSFWorkbook(fs)
//一共有几张表
int sheet_num=workbook.getNumberOfSheets()
setSheetNumber(0)
setProcess(0)//开始
//循环每个表
for(int i=0i<sheet_numi++){
HSSFSheet sheet=workbook.getSheetAt(i)
setSheetNumber(i+1)
if(sheet!=null&&sheet.getPhysicalNumberOfRows()!=0){
int topicNumberNum=Integer.parseInt(topicNumber)//越过首行的标题(如果有)
totalNumber=sheet.getPhysicalNumberOfRows()-topicNumberNum
//循环各个行
for(int j=sheet.getFirstRowNum()+topicNumberNumj<=sheet.getPhysicalNumberOfRows()j++){
HSSFRow row=sheet.getRow(j)
String aircraft=null
//String aircraftType=null
Double takeoffWeight=0.00
Double payloadMax2=0.00
int seatNumberMax2=0
if(row!=null&&row.getPhysicalNumberOfCells()!=0){
switch(row.getCell(0).getCellType()){
case Cell.CELL_TYPE_STRING:
aircraft=(row.getCell(0).getStringCellValue()).trim()
break
case Cell.CELL_TYPE_NUMERIC:
aircraft=String.valueOf(row.getCell(0).getNumericCellValue()).trim()
break
}
//继续处理其他单元格、行
}
//存入数据库
AircraftTableActionForm atb=new AircraftTableActionForm()
if(aircraft!=null&&!aircraft.equals("")){
atb.setAircraft(aircraft)
//set其他值
updateByExcel(atb)!=-1
}
}
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)