当前位置:文档之家› 解决大批量数据导出Excel产生内存溢出的方案

解决大批量数据导出Excel产生内存溢出的方案

解决大批量数据导出Excel产生内存溢出的方案
解决大批量数据导出Excel产生内存溢出的方案

POI或者JXL在导出大量数据的时候,由于它们将每一个单元格生都成一个Cell对象,所以很容易导致内存溢出。解决这个问题,唯一的办法是弄清楚Excel的二进制格式(汗),并且用流的方式读写Excel。POI和JXL其实提供了二进制方式读写Excel的API,只是因为缺少文档和实例,所以使用的人不多。我编写了这个简单的合并Excel的类,它只适合合并结构相同的多个Excel文件。好在这个功能已经可以解决数据导出产生OOM的问题:将数据分批导出然后合并。

下面的代码使用POI3.1,合并11个3000多行的文档用时约6秒,我实在找不到更多的测试用的文档了。

Java代码

@SuppressWarnings("unchecked")

public class XlsMergeUtil {

private static Logger logger = LoggerFactory.getLogger(XlsMergeUtil.class);

/**

* 将多个Xls文件合并为一个,适用于只有一个sheet,并且格式相同的文档

* @param inputs 输入的Xls文件

* @param out 输出文件

*/

public static void merge(InputStream[] inputs, OutputStream out) {

if (inputs == null || inputs.length <= 1) {

throw new IllegalArgumentException("没有传入输入流数组,或只有一个输入流.");

}

List rootRecords = getRecords(inputs[0]);

Workbook workbook = Workbook.createWorkbook(rootRecords);

List sheets = getSheets(workbook, rootRecords);

if(sheets == null || sheets.size() == 0) {

throw new IllegalArgumentException("第一篇文档的格式错误,必须有至少一个sheet");

}

//以第一篇文档的最后一个sheet为根,以后的数据都追加在这个sheet后面

Sheet rootSheet = sheets.get(sheets.size() - 1);

int rootRows = getRowsOfSheet(rootSheet); //记录第一篇文档的行数,以后的行数在此基础上增加

rootSheet.setLoc(rootSheet.getDimsLoc());

Map map = new HashMap(10000);

for (int i = 1; i < inputs.length; i++) { //从第二篇开始遍历

List records = getRecords(inputs[i]);

int rowsOfCurXls = 0;

//遍历当前文档的每一个record

for (Iterator itr = records.iterator(); itr.hasNext();) {

Record record = (Record) itr.next();

if (record.getSid() == RowRecord.sid) { //如果是RowRecord

RowRecord rowRecord = (RowRecord) record;

//调整行号

rowRecord.setRowNumber(rootRows + rowRecord.getRowNumber());

rootSheet.addRow(rowRecord); //追加Row

rowsOfCurXls++; //记录当前文档的行数

}

//SST记录,SST保存xls文件中唯一的String,各个String都是对应着SST记录的索引

else if (record.getSid() == SSTRecord.sid) {

SSTRecord sstRecord = (SSTRecord) record;

for (int j = 0; j < sstRecord.getNumUniqueStrings(); j++) {

int index = workbook.addSSTString(sstRecord.getString(j));

//记录原来的索引和现在的索引的对应关系

map.put(Integer.valueOf(j), Integer.valueOf(index));

}

} else if (record.getSid() == LabelSSTRecord.sid) {

LabelSSTRecord label = (LabelSSTRecord) record;

//调整SST索引的对应关系

label.setSSTIndex(map.get(Integer.valueOf(label.getSSTIndex())));

}

//追加ValueCell

if (record instanceof CellValueRecordInterface) {

CellValueRecordInterface cell = (CellValueRecordInterface) record;

int cellRow = cell.getRow() + rootRows;

cell.setRow(cellRow);

rootSheet.addValueRecord(cellRow, cell);

}

}

rootRows += rowsOfCurXls;

}

byte[] data = getBytes(workbook, sheets.toArray(new Sheet[0]));

write(out, data);

}

static void write(OutputStream out, byte[] data) {

POIFSFileSystem fs = new POIFSFileSystem();

// Write out the Workbook stream

try {

fs.createDocument(new ByteArrayInputStream(data), "Workbook");

fs.writeFilesystem(out);

out.flush();

} catch (IOException e) {

e.printStackTrace();

} finally {

try {

out.close();

} catch (IOException e) {

e.printStackTrace();

}

}

}

static List getSheets(Workbook workbook, List records) {

int recOffset = workbook.getNumRecords();

int sheetNum = 0;

// convert all LabelRecord records to LabelSSTRecord convertLabelRecords(records, recOffset, workbook);

List sheets = new ArrayList();

while (recOffset < records.size()) {

Sheet sh = Sheet.createSheet(records, sheetNum++, recOffset);

recOffset = sh.getEofLoc() + 1;

if (recOffset == 1) {

break;

}

sheets.add(sh);

}

return sheets;

}

static int getRows(List records) {

int row = 0;

for (Iterator itr = records.iterator(); itr.hasNext();) {

Record record = (Record) itr.next();

if (record.getSid() == RowRecord.sid) {

row++;

}

}

return row;

}

static int getRowsOfSheet(Sheet sheet) {

int rows = 0;

sheet.setLoc(0);

while(sheet.getNextRow() != null) {

rows++;

}

return rows;

}

@SuppressWarnings("deprecation")

static List getRecords(InputStream input) {

try {

POIFSFileSystem poifs = new POIFSFileSystem(input);

InputStream stream = poifs.getRoot().createDocumentInputStream("Workbook");

return org.apache.poi.hssf.record.RecordFactory.createRecords(stream);

} catch (IOException e) {

logger.error("IO异常:{}", e.getMessage());

e.printStackTrace();

}

return Collections.EMPTY_LIST;

}

static void convertLabelRecords(List records, int offset, Workbook workbook) {

for (int k = offset; k < records.size(); k++) {

Record rec = (Record) records.get(k);

if (rec.getSid() == LabelRecord.sid) {

LabelRecord oldrec = (LabelRecord) rec;

records.remove(k);

LabelSSTRecord newrec = new LabelSSTRecord();

int stringid = workbook.addSSTString(new UnicodeString(oldrec.getValue()));

newrec.setRow(oldrec.getRow());

newrec.setColumn(oldrec.getColumn());

newrec.setXFIndex(oldrec.getXFIndex());

newrec.setSSTIndex(stringid);

records.add(k, newrec);

}

}

}

public static byte[] getBytes(Workbook workbook, Sheet[] sheets) {

// HSSFSheet[] sheets = getSheets();

int nSheets = sheets.length;

// before getting the workbook size we must tell the sheets that

// serialization is about to occur.

for (int i = 0; i < nSheets; i++) {

sheets[i].preSerialize();

}

int totalsize = workbook.getSize();

// pre-calculate all the sheet sizes and set BOF indexes

int[] estimatedSheetSizes = new int[nSheets];

for (int k = 0; k < nSheets; k++) {

workbook.setSheetBof(k, totalsize);

int sheetSize = sheets[k].getSize();

estimatedSheetSizes[k] = sheetSize;

totalsize += sheetSize;

}

byte[] retval = new byte[totalsize];

int pos = workbook.serialize(0, retval);

for (int k = 0; k < nSheets; k++) {

int serializedSize = sheets[k].serialize(pos, retval);

if (serializedSize != estimatedSheetSizes[k]) {

throw new IllegalStateException("Actual serialized sheet size (" + serializedSize

+ ") differs from pre-calculated size (" + estimatedSheetSizes[k] + ") for sheet (" + k

+ ")");

Sheet.serializeIndexRecord() does not

}

pos += serializedSize;

}

return retval;

}

public static void main(String[] args) throws Exception {

final String PATH = "E:\\projects\\java\\ws_0\\export\\data\\";

InputStream[] inputs = new InputStream[10];

inputs[0] = new java.io.FileInputStream(PATH + "07_10.xls");

for(int i = 1; i <= 9; i++) {

inputs[i] = new java.io.FileInputStream(PATH + "07_0" + i + ".xls");

}

OutputStream out = new FileOutputStream(PATH + "xx.xls");

long t1 = System.currentTimeMillis();

merge(inputs, out);

System.out.println(System.currentTimeMillis() - t1);//简陋的测试一下时间

}

}

讲讲解决方法,

一般导出的Excel用来做报表或者统计用的,也不要求图片或其它对象,就是数据,

我的做法是写文本格式的Excel文件,而不是用POI等生成二进制的文件,

第一种格式,CSV,最简单的,格式最差,最基本的行列,不能合并,不能设置着色,

第二种,HTML格式的,如:"

....
"这样的文本,后辍名改为XLS就可以了,可以设置跨行列的合并,可以着色,图片没试过,估计是可以的,还可以设置单元格对齐,单元格的格式等,

写文本的时候,根本不用担心OOM的问题,我最大写过500多M的一个excel文件,不过这已经没有意义了,excel一个Sheet最大6万多行,多了也显示不出来.

这样做的缺点:

上面的办法我也用过,的确没有溢出的问题,不过客户不同意的。我们现在的这个的客户很各色,以前其他的客户就可以用你的办法搞定。比如客户要求一次导出20w行数据,这就要求导出的文件必须带sheet,上面的代码也不支持sheet,下面的就可以了:

@SuppressWarnings("unchecked")

public class XlsMergeUtil {

private static Logger logger = LoggerFactory.getLogger(XlsMergeUtil.class);

/**

* 将多个Xls文件合并为一个,适用于只有一个sheet,并且格式相同的文档

* @param inputs 输入的Xls文件,第一个XLS文件必须给出足够sheet空间

* 例如,总共200000行数据,第一个文件至少3个空白sheet

* @param out 输出文件

*/

public static void merge(InputStream[] inputs, OutputStream out) {

if (inputs == null || inputs.length <= 1) {

throw new IllegalArgumentException("没有传入输入流数组,或只有一个输入流.");

}

List rootRecords = getRecords(inputs[0]);

Workbook workbook = Workbook.createWorkbook(rootRecords);

List sheets = getSheets(workbook, rootRecords);

if(sheets == null || sheets.size() == 0) {

throw new IllegalArgumentException("第一篇文档的格式错误,必须有至少一个sheet");

}

//以第一篇文档的第一个sheet为根,以后的数据都追加在这个sheet后面

Sheet rootSheet = sheets.get(0);

int rootRows = getRowsOfSheet(rootSheet); //记录第一篇文档的行数,以后的行数在此基础上增加

rootSheet.setLoc(rootSheet.getDimsLoc());

Map map = new HashMap(10000);

int sheetIndex = 0;

for (int i = 1; i < inputs.length; i++) { //从第二篇开始遍历

List records = getRecords(inputs[i]);

//达到最大行数限制,换一个sheet

if(getRows(records) + rootRows >= RowRecord.MAX_ROW_NUMBER) {

if((++sheetIndex) > (sheets.size() - 1)) {

logger.warn("第一个文档给出的sheets小于需要的数量,部分数据未能合并.");

break;

}

rootSheet = sheets.get(sheetIndex);

rootRows = getRowsOfSheet(rootSheet);

rootSheet.setLoc(rootSheet.getDimsLoc());

logger.debug("切换Sheet{}", sheetIndex);

}

int rowsOfCurXls = 0;

//遍历当前文档的每一个record

for (Iterator itr = records.iterator(); itr.hasNext();) {

Record record = (Record) itr.next();

if (record.getSid() == RowRecord.sid) { //如果是RowRecord

RowRecord rowRecord = (RowRecord) record;

//调整行号

rowRecord.setRowNumber(rootRows + rowRecord.getRowNumber());

rootSheet.addRow(rowRecord); //追加Row

rowsOfCurXls++; //记录当前文档的行数

}

//SST记录,SST保存xls文件中唯一的String,各个String都是对应着SST记录的索引

else if (record.getSid() == SSTRecord.sid) {

SSTRecord sstRecord = (SSTRecord) record;

for (int j = 0; j < sstRecord.getNumUniqueStrings(); j++) {

int index = workbook.addSSTString(sstRecord.getString(j));

//记录原来的索引和现在的索引的对应关系

map.put(Integer.valueOf(j), Integer.valueOf(index));

}

} else if (record.getSid() == LabelSSTRecord.sid) {

LabelSSTRecord label = (LabelSSTRecord) record;

//调整SST索引的对应关系

label.setSSTIndex(map.get(Integer.valueOf(label.getSSTIndex())));

}

//追加ValueCell

if (record instanceof CellValueRecordInterface) {

CellValueRecordInterface cell = (CellValueRecordInterface) record;

int cellRow = cell.getRow() + rootRows;

cell.setRow(cellRow);

rootSheet.addValueRecord(cellRow, cell);

}

}

rootRows += rowsOfCurXls;

}

byte[] data = getBytes(workbook, sheets.toArray(new Sheet[0])); write(out, data);

}

static void write(OutputStream out, byte[] data) { POIFSFileSystem fs = new POIFSFileSystem();

// Write out the Workbook stream

try {

fs.createDocument(new ByteArrayInputStream(data), "Workbook");

fs.writeFilesystem(out);

out.flush();

} catch (IOException e) {

e.printStackTrace();

} finally {

try {

out.close();

} catch (IOException e) {

e.printStackTrace();

}

}

}

static List getSheets(Workbook workbook, List records) {

int recOffset = workbook.getNumRecords();

int sheetNum = 0;

// convert all LabelRecord records to LabelSSTRecord convertLabelRecords(records, recOffset, workbook);

List sheets = new ArrayList();

while (recOffset < records.size()) {

Sheet sh = Sheet.createSheet(records, sheetNum++, recOffset);

recOffset = sh.getEofLoc() + 1;

if (recOffset == 1) {

break;

}

sheets.add(sh);

}

return sheets;

}

static int getRows(List records) {

int row = 0;

for (Iterator itr = records.iterator(); itr.hasNext();) {

Record record = (Record) itr.next();

if (record.getSid() == RowRecord.sid) {

row++;

}

}

return row;

}

static int getRowsOfSheet(Sheet sheet) {

int rows = 0;

sheet.setLoc(0);

while(sheet.getNextRow() != null) {

rows++;

}

return rows;

}

@SuppressWarnings("deprecation")

static List getRecords(InputStream input) {

try {

POIFSFileSystem poifs = new POIFSFileSystem(input);

InputStream stream = poifs.getRoot().createDocumentInputStream("Workbook");

return org.apache.poi.hssf.record.RecordFactory.createRecords(stream);

} catch (IOException e) {

logger.error("IO异常:{}", e.getMessage());

e.printStackTrace();

}

return Collections.EMPTY_LIST;

}

static void convertLabelRecords(List records, int offset, Workbook workbook) {

for (int k = offset; k < records.size(); k++) {

Record rec = (Record) records.get(k);

if (rec.getSid() == LabelRecord.sid) {

LabelRecord oldrec = (LabelRecord) rec;

records.remove(k);

LabelSSTRecord newrec = new LabelSSTRecord();

int stringid = workbook.addSSTString(new UnicodeString(oldrec.getValue()));

newrec.setRow(oldrec.getRow());

newrec.setColumn(oldrec.getColumn());

newrec.setXFIndex(oldrec.getXFIndex());

newrec.setSSTIndex(stringid);

records.add(k, newrec);

}

}

}

public static byte[] getBytes(Workbook workbook, Sheet[] sheets) {

// HSSFSheet[] sheets = getSheets();

int nSheets = sheets.length;

// before getting the workbook size we must tell the sheets that

// serialization is about to occur.

for (int i = 0; i < nSheets; i++) {

sheets[i].preSerialize();

}

int totalsize = workbook.getSize();

// pre-calculate all the sheet sizes and set BOF indexes

int[] estimatedSheetSizes = new int[nSheets];

for (int k = 0; k < nSheets; k++) {

workbook.setSheetBof(k, totalsize);

int sheetSize = sheets[k].getSize();

estimatedSheetSizes[k] = sheetSize;

totalsize += sheetSize;

}

logger.debug("分配内存{}bytes", totalsize);

byte[] retval = new byte[totalsize];

int pos = workbook.serialize(0, retval);

for (int k = 0; k < nSheets; k++) {

int serializedSize = sheets[k].serialize(pos, retval);

if (serializedSize != estimatedSheetSizes[k]) {

// Wrong offset values have been passed in the call to setSheetBof() above.

// For books with more than one sheet, this discrepancy would cause excel

// to report errors and loose data while reading the workbook

throw new IllegalStateException("Actual serialized sheet size (" + serializedSize

+ ") differs from pre-calculated size (" + estimatedSheetSizes[k] + ") for sheet (" + k

+ ")");

// TODO - add similar sanity check to ensure that Sheet.serializeIndexRecord() does not

// write mis-aligned offsets either

}

pos += serializedSize;

}

return retval;

}

public static void main(String[] args) throws Exception {

final String PATH = "E:\\projects\\java\\ws_0\\export\\data\\";

InputStream[] inputs = new InputStream[25];

inputs[0] = new java.io.FileInputStream(PATH + "07_10.xls");

for(int i = 1; i < 25 ; i++) {

inputs[i] = new java.io.FileInputStream(PATH + "07_01.xls");

}

OutputStream out = new FileOutputStream(PATH + "xx.xls");

long t1 = System.currentTimeMillis();

merge(inputs, out);

System.out.println(System.currentTimeMillis() - t1);

}

}

此文档为网站转载。

vfp直接读取EXCEL文件示例

vfp直接读取EXCEL文件示例 vfp直接读取EXCEL文件的示例(转)。 M_File=GETFILE('xls','订单文件') IF M_File="" =MESSAGEBOX("请选择待导入的收订单文件!",0+48,"提示") RETURN ELSE IF JUSTEXT(M_FILE)#"XLS" &&获得文件扩展名 =MESSAGEBOX("您选择的不是EXCEL文档!",0+48,"提示") RETURN ENDIF ENDIF USE 图书订单表 ZAP myexcel=createobject('excel.application') &&创建一个对象 myexcel.visible=.f.&&不可见 bookexcel=myexcel.workbooks.open(M_File) &&打开指定文件 o_SheetName=https://www.doczj.com/doc/605890267.html,&&获取当前激活工作表的名称UsedRange =bookexcel.worksheets(o_SheetName).UsedRange&&返回工作表中可使用的区域,UsedRange表的属性 o_rows=UsedRange.rows.count&&汇总行 o_cols=UsedRange.columns.count&&汇总列 IF o_rows<=1 =MESSAGEBOX("待导入数据行数太少,请检查!",0+16,"提示") ELSE FOR i=2 TO o_rows m1=myexcel.cells(i,1).value &&书号 m2=myexcel.cells(i,2).value &&书名 m3=myexcel.cells(i,3).value &&出版社 m4=myexcel.cells(i,4).value &&作者 m5=myexcel.cells(i,5).value &&定价 m6=myexcel.cells(i,6).value &&数量 APPEND BLANK REPLACE 书号WITH m1,书名WITH m2,出版社WITH m3,作者WITH m4,定价WITH m5,数量WITH m6 ENDFOR ENDIF myexcel.workbooks.close&&关闭工作区 myexcel.quit&&关闭excel brow

在VFP中直接来控制Excel

Example: SET DEFAULT TO c:\ clear oleapp=createobject("excel.application") oleapp.visible=.t. && 显示Excel oleapp.workbooks.add **设单元格的值(报表标题): oleapp.cells(1,1).value="aaa" oleapp.cells(1,2).value="bbb" oleapp.cells(1,3).value="ccc" oleapp.cells(1,4).value="ddd" oleapp.cells(1,5).value="eee" **打开表并取得记录数 USE c:\bank\data\zyb.dbf SHARED jl=reccount()-1 &&记录数 **将表中的记录数据放到Excel工作簿的单元格中 for i=0 to jl go i+1 &&第i+1条记录 oleapp.cells(2+i,1).value=zyb.bh oleapp.cells(2+i,2).value=zyb.xm oleapp.cells(2+i,3).value=zyb.kl oleapp.cells(2+i,4).value=1+1 endfor oleapp.activeworkbook.saveas("C:\Documents and Settings\Administrator\桌面\KL.xls") * oleapp.activeworkbook.saveas(?) ********************************************************* 利用VFP进行处理数据,而利用Excel的预览打印功能进行报表打印。这就需要我们在VFP中直接来控制Excel。下面就在开发VFP应用项目时对Excel的控制作一下介绍: 1.创建Excel对象 eole=CREATEOBJECT(′Excel.application′) 2.添加新工作簿 eole.Workbooks.add 3.设置第3个工作表为激活工作表 eole.Worksheets(″sheet3″).Activate 4.打开指定工作簿 eole.Workbooks.Open(″c:\temp\ll.x ls″) 5.显示Excel窗口 eole.visible=.t. 6.更改Excel标题栏 eole.Caption=″VFP应用程序调用Microsoft Excel″ 7.给单元格赋值 eole.cells(1,4).value=XM(XM为数据库字段名) 8.设置指定列的宽度(单位:字符个数)

Java实现Excel数据导入和导出的研究与应用

Java实现Excel数据导入导出的研究与应用 王晶晶 北京邮电大学网络教育学院(100088) E-mail:bolalisi_double@https://www.doczj.com/doc/605890267.html, 摘要:Excel能够通过功能强大的工具将杂乱的数据组织成有用的信息,然后分析、交流和共享所得到的结果。很多系统由于存在着大量需要处理的数据,Excel本身强大的功能使得它成为处理分析这些数据首选的工具。随着Java语言成为越来越多系统的开发语言,利用Java进行Excel的数据导入导出在很多系统中都发挥着重要的作用,本文主要介绍了Jxl API的主要功能,并结合实例探讨了利用Jxl API操作Excel数据的导入和导出。 关键字:Java;Excel; Jxl API;数据导入导出 中图分类号:TP312文献标识码:A 1. 引言 MS的电子表格(Excel)是Office的重要成员,是保存统计数据的一种常用格式。在一个Java应用中,将一部分数据生成Excel格式,是与其他系统无缝连接的重要手段。在远程网络教学系统中,利用Excel表格统计学生的作业考试情况信息,便于老师了解学生的学习情况,分析教学效果,制定教学计划。所以,用Java操作Excel表格,导出相关的信息对于远程网络教育系统有着的很重要的意义。 在开源世界中,有两套比较有影响的API提供Excel数据导入导出的功能,一个是POI,一个是jExcelAPI。本文结合基于J2EE开发的多媒体教学系统中提供的将学生作业信息导出到Excel表格中的实例,详细阐述了利用JAVA开发的jExcelAPI操作excel的方法。 2. Jxl 简介 2.1 Java语言简介 Java语言具有面向对象、与平台无关、安全、稳定和多线程等优良特性,是目前软件设计中极为强大的编程语言[1]。它具有以下一些特点[2]:简单,面向对象,分布式,解释执行,鲁棒,安全,体系结构中立,可移植,高性能,多线程以及动态性。 2.2什么是Jxl Java Excel是一开放源码项目,通过它Java开发人员可以读取Excel文件的内容、创建新的Excel文件、更新已经存在的Excel文件。使用该 API非Windows操作系统也可以通过纯Java应用来处理Excel数据表。因为是使用Java编写的,所以我们在Web应用中可以通过JSP、 Servlet来调用API实现对Excel数据表的访问。 Jxl发布的稳定版本是V2.0,提供以下功能: 从Excel 95、97、2000等格式的文件中读取数据[3]; 读取Excel公式(可以读取Excel 97以后的公式)[3];

.NET页面数据导出excel表方法

public void CreateExcel(DataSet ds,string typeid,string FileName) { HttpResponse resp; resp = Page.Response; resp.ContentEncoding = System.Text.Encoding.GetEncoding("GB2312"); resp.AppendHeader("Content-Disposition", "attachment;filename=" + FileName); string colHeaders= "", ls_item=""; int i=0; //定义表对象与行对像,同时用DataSet对其值进行初始化 DataTable dt=ds.Tables[0]; DataRow[] myRow=dt.Select(""); // typeid=="1"时导出为EXCEL格式文件;typeid=="2"时导出为XML格式文件if(typeid=="1") { //取得数据表各列标题,各标题之间以\t分割,最后一个列标题后加回车符for(i=0;i colHeaders+=dt.Columns[i].Caption.ToString()+"\t"; colHeaders +=dt.Columns[i].Caption.ToString() +"\n"; //向HTTP输出流中写入取得的数据信息 resp.Write(colHeaders); //逐行处理数据 foreach(DataRow row in myRow) { //在当前行中,逐列获得数据,数据之间以\t分割,结束时加回车符\n for(i=0;i ls_item +=row[i].ToString() + "\t"; ls_item += row[i].ToString() +"\n"; //当前行数据写入HTTP输出流,并且置空ls_item以便下行数据 resp.Write(ls_item); ls_item=""; } } else { if(typeid=="2") { //从DataSet中直接导出XML数据并且写到HTTP输出流中 resp.Write(ds.GetXml()); } } //写缓冲区中的数据到HTTP头文件中 resp.End(); }

从SQL Server中导入导出Excel的基本方法

从sql server中导入/导出excel 的基本方法 /*=========== 导入/导出excel 的基本方法===========*/ 从excel文档中,导入数据到sql数据库中,很简单,直接用下面的语句: /*=============================================*/ --假如接受数据导入的表已存在 insert into 表select * from openrowset(microsoft.jet.oledb.4.0 ,excel 5.0;hdr=yes;database=c:test.xls,sheet1$) --假如导入数据并生成表 select * into 表from openrowset(microsoft.jet.oledb.4.0 ,excel 5.0;hdr=yes;database=c:test.xls,sheet1$) /*===========================================*/ --假如从sql数据库中,导出数据到excel,假如excel文档已存在,而且已按照要接收的数据创建好表头,就能够简单的用: insert into openrowset(microsoft.jet.oledb.4.0 ,excel 5.0;hdr=yes;database=c:test.xls,sheet1$) select * from 表 --假如excel文档不存在,也能够用bcp来导成类excel的文档,注意大小写: --导出表的情况 exec master..xp_cmdshell bcp 数据库名.dbo.表名out "c:test.xls" /c -/s"服务器名" /u"用户名" -p"密码" --导出查询的情况 exec master..xp_cmdshell bcp "select au_fname, au_lname from pubs..authors order by au_lname" queryout "c:test.xls" /c -/s"服务器名" /u"用户名" -p"密码" /*--说明: c:test.xls 为导入/导出的excel文档名. sheet1$ 为excel文档的工作表名,一般要加上$才能正常使用. --*/ --上面已说过,用bcp导出的是类excel文档,其实质为文本文档, --要导出真正的excel文档.就用下面的方法

图解把EXCEL数据导入到SQL SERVER 2008

实验环境:WIN XP,MS Office Excel2007,Sql Server2008 准备数据:Excel文档:D:\test\重复出修率.xlsx 方法一: 第一步:打开SSMS: 【开始】→【所有程序】→【Microsoft Sql Server2008】→【Sql Server Management Studio】

第二步:连接数据库: 在’对象资源管理器’中点击【连接】→【数据库引擎】登陆服务器 (P.S:如果没有看到’对象资源管理器’,点击左上角的【视图】→【对象管理器】) 第三步:登陆成功后,右击你要导入数据的数据库名,我这里数据库名是’TEST’ 右击【TEST】→【任务】→【导入数据】

这时候会出现一个向导:点击【下一步】 在弹出的窗口中,【数据源】选择:Microsoft Excel; 【Excel文件路径】就选择你本地电脑存放Excel文档的路径,我这里是D:\test\重复出修率.xlsx 【Excel版本】选择Excel2007(可以根据你office的版本,选择其他如Excel2003等等。)选中【首行包含列名称】框,最后点击【下一步】 “首行包含列名称”是指Excel中的首行数据插入数据库后将作为新建表的列名.

在弹出窗口中,【目标】可以采取默认的,【服务器名称】也是一样可以选择身份验证,最后选择你要插入数据到哪个数据库中。 如我这里选的是’TEST’,选好后点击【下一步】

如果就把Excel数据插入一个新表,就选择【复制一个或多个表或视图的数据】 如果想把Excel数据插入到已存在的一张表中,则选择下面的【编写查询以指定要传输的数据】 我这里是选择上面一个,然后点击【下一步】 接着会弹出Excel表中的sheet表名字,如果你没有修改过sheet表名字,则可能显示的是’shee1$’,’shee2$’,’shee3$’等等. 然后你选中你想要导入的哪张表的数据,我这里导入的是【’aug$’】 选中后,右边的【目标】栏位中会出现内容, dbo是指数据库的架构名,aug$只是新建的表名,如果你想修改表明,双击就可以表明进入编辑状态就可以修改了。我这里修改的表名称为:aug_info

从VFP中导出数据的几种方法

从VFP中导出数据的几种方法 出处:网络 当VFP处理好数据后,这时你可以用多种方法将这些数据导出,以便被其它应用程序(如Excel等)所用。下面向你简单介绍几种导出数据的方法: 1.用“导出数据”对话框。你可以从VFP主菜单中选择“文件/导出…”打开“导出”对话框,在该对话框中的“来源”框中输入表名(c:vfpstudents.dbf),在“类型”中指定要导出数据的类型(Microsoft Excel),在“到”框中输入导出的路径和文件名(C:excelaa.xls),然后按“确定”即可。这时你如果查看command窗口,可发现以下代码: COPY TO C:excelaa.XLS TYPE XL5 2.用COPY TO命令。COPY TO命令的工作对象是VFP中的表,它要依据“TYPE”项才知道要产生哪一类导出文件。对于上面的导出过程,可用以下方法实现:USE students COPY TO C:excelaa.XLS TYPE XL5 3.用SET ALTERNATE TO写入ASCⅡ文件。用该命令可以把屏幕上的内容导出,导向一个文件,下面例子可以将系统状态输入到status.txt文件中: SET ALTERNATE TO status.txt SET ALTERNATE ON SET CONSOLE OFF ?“系统状态”+DTOC(DATE())+“@”+TIME() LIST STATUS SET ALTERNATE OFF SET CONSOLE ON 4.用SET PRINTER TO命令。用该命令可把打印输出到文本文件中: SET PRINTER TO hello.txt SET PRINT ON ???CHR(27)+“广大计算机爱好者” ??“你们好!” ?“祝你们新年快乐” SET PRINT OFF 5.用REPORT FORM TO FILE命令。运行报表的REPORT命令有许多选项,把报表输出保存到文件中的方法为: REPORT FORM(报表名)TO FILE(文件名)

导出数据到EXCEL

Private Sub Command1_Click() Dim 文件名称As String 文件名称= "C:\Documents and Settings\Administrator\桌面\Hellod.Doc " Dim uObjDoc As Word.Document Set uObjWord = New Word.Application uObjWord.Documents.Add "Normal", IIf(iMode = 1, True, False) '1、根据"Normal"模板添加一个新的文档[1-创建一个模板,0-创建一个文件] uObjWord.Documents.Save NoPrompt:=True, OriginalFormat:=wdWordDocument '2、设置Word对象为自动保存模式 uObjWord.ActiveDocument.SaveAs 文件名称'3、保存Word文档到文件名称 Set uObjDoc = Nothing End Sub EXCEL用法 Public Function ExporToExcel(strOpen As String) '********************************************************* '* 名称:ExporToExcel '* 功能:导出数据到EXCEL '* 用法:ExporToExcel(sql查询字符串) '********************************************************* Dim Rs_Data As New ADODB.Recordset Dim Irowcount As Integer Dim Icolcount As Integer Dim xlApp As New Excel.Application Dim xlBook As Excel.Workbook Dim xlSheet As Excel.Worksheet Dim xlQuery As Excel.QueryTable With Rs_Data If .State = adStateOpen Then .Close End If .ActiveConnection = Cn .CursorLocation = adUseClient .CursorType = adOpenStatic .LockType = adLockReadOnly .Source = strOpen .Open End With

用Excel获取网页内容的方法

在浏览网页时,你一定会不时看到一些需要保存的数据信息。这些信息或许是一个完整的表格,或许是一段文字,如果要保存这类信息,我们常用的方法就是拖动鼠标,选中这些信息,然后用Ctrl+C组合键复制文字,然后再保存到Word、Excel当中去。 这样的步骤算不上麻烦,但如果要求你在一个个内容丰富的大网页(比如新浪、网易、Sohu首页)中频繁地复制、粘贴,一定会让你感到疲劳和浪费时间。有什么好办法呢?用“Ctrl+A”全选后复制所有文字?粘贴后你会发现麻烦更大,因为所有文字都堆在一起了!下面,理睬教你一种方便的方法。 实例:抓取新浪首页不同位置内容 第一步:打开IE,访问理睬博客首页https://www.doczj.com/doc/605890267.html,/ 。 第二步:在网页左侧或右侧的空白处点击鼠标右键,在菜单中选择“导出到Microsoft Office Excel”。注意,不要在文字链接之间的空白处点右键,而是应该在完全没有任何网页内容的地方点右键。 第三步:这时Excel会启动,并出现一个“新建Web查询”的窗口。稍等片刻,等待这个窗口中显示出了完整网页,左下角会出现“完毕”字样。注意观察网页,你会发现网页被分割成了很多小的表格,每个表格的左上角有一个小的箭头标志。 第四步:双击窗口最上方标题栏,最大化窗口。依次找到要收藏的内容,然后按下该位置左上角的箭头,使它变成绿色的对勾。然后按下下方的“导入”按钮。 第五步:在弹出窗口中选择放置位置,然后按下“确定”按钮,文字、表格信息就可以自动导入Excel 了。字体格式、颜色自动处理为Excel默认的样式,表格也会被放到适当的单元格中。这样,就有效避免了直接复制粘贴网页造成一些无法识别的格式、链接信息加入网页,同时提高了导入速度。 你知道吗? 如何不将网页格式带入Office文档中? 当你在浏览器中复制一段内容,然后粘贴到Word、Excel中,会将一些网页格式直接照搬进来,这可能不是我们希望的,因为它会增大文件体积,也不利于加工整理。其实,你只要不用“Ctrl+V”来粘贴,而是选择Word、Excel中的“编辑→选择性粘贴→文本”来进行粘贴就可以了。

VFP数据导出到EXCEL技术

VFP数据导出到EXCEL技术 VFP数据导出到EXCEL技术 我们都知道在EXCEL 中有很多很多的计算公式、灵活多变的计算方式、方便快捷的图表处理、和功能强大的VBA 语言,可以说EXCEL 可能是最好用的表格处理软件。我敢说:微软的产品中大概就EXCEL 最好! 但是,怎样用Foxpro 快速产生统计表,并将数据送到Excel 表格中,从而代替Foxpro 的报表工具呢? 我们大家都知道,在Visual Foxpro 3.0及以后版本中提供了一个调用Ole Automation 的函数CREATEOBJECT,用该函数可以让Visual Foxpro 很方便的和其它可以提供Ole Automation 服务的程序进行通讯。而Excel 更是一个标准的Ole Automation 服务器程序,我们可以在前端将数据传送到后端的Excel 服务程序,用后端服务程序进行表格处理,从而弥补Visual Foxpro的不足。由于历史原因,我们作报表都习惯用Total、Count、Sum 或者直接在报表中工具中计算,速度最快的大概也就是Total 了,但不知道还有多少人还在坚持使用Total 命令进行计算,有没有更好的计算方法呢?当然有啦!我在实际使用中积累有一定的经验但愿能给各位起到小小的启发。 假设有一表:Table1 是一个人员档案,里面的表结构如下:

-----字段名--类型及长度---------编号C,2 部门C,10 姓名C,10 性别C,2 出生日期 D 职务C,10 文化程度C,10 内容大概如下 TABLE1.DBF ------------------------- --------编号部门姓名性别出生日期职务 文化程度---------------------------------1 工程部张三男1971-01-11 工程师大学本科 2 销售部李四男1967-02-23 经理大学本科 3 工程部王武1954-03-14 技术员大学专科4 总经理室赵洁雅女1975-04-05 秘书硕士研究生5 销售部..1977-05-09 销售经理高中 6 工程部大文 1969-03-30 总工程师大学专科7 销售部..1961-10-10 销售经理大学专科8 总经理室庄稼1961-10-10 总经理大学专科当然实际的数据应该比这里多很多,要不还用统计干吗,我不过是举例说明而已。我不知道你们在使用SQL

Excel 数据导入教程

Excel模板数据导入教程 Excel模板数据导入教程 Excel导入模板中的数据既可以直接在我们提供的模板文件中录入,列标题中有红色“(必填)”文字的列必须要填写,其它列根据实际需求可以不填写,换算比率、销售价格、库存数量、成本价这些数字列如果要导入的话,一定是纯数字格式,必须要填写而且不能包括任何汉字或字母。 库存数量与成本价必须是以基本计量单位核算录入,也就是以最小计量单位核算录入。 如果从管家婆、速达等进销存软件中导出到Excel文件,一定要修改导出的Excel文件格式,否则肯定不能正常识别和导入,修改的要求如下: 1、Excel导入模板文件扩展名必须为xls,如果为其它扩展名,必须双击打开模板文件,然后另存为“Excel97-2003工作簿(*.xls)”格式的文件; 2、窗口左下角的工作薄名称必须为“Sheet1”,管家婆或速达导出来的工作薄名称一般为其它名称,必须要修改为Sheet1,请见以下截图; 3、第一行必须为列名,第二行开始必须为要导入的正式数据,请见以下截图;

附上一张标准的导入模板数据截图 本教程只演示怎么导入在我们提供的Excel导入模板中录入的数据,如果从管家婆或速达等进销存软件导出来的数据,导入方式大同小异,只是列名或列的数量不一致而已; 在导入之前一定要关闭要导入的Excel模板文件,否则因为独占模式导致导入时无法识别模板文件中的数据。 产品资料导入 产品资料模板中包括“产品资料基础信息、销售价格、库存记录”3部分内容,需要将同一个产品资料模板文件分3步分别导入,如果有辅助计量单位的销售价格也需要导入,那么需要分4步分别导入。 在导入的模板中如果包括软件中已存在的产品资料记录,一定要在导入窗口将 下拉框选择,这样就不会将相同的记录重复导入到软件中。 第一步:既可以在软件初次使用向导窗口中点击“产品资料导入”按钮,也可以在“基础数据----产品资料”列表窗口点击“Excel导入”菜单,弹出产品资料导入窗口,先选择要导入的Excel模板文件,然后根据要导入的列,按照以下截图设置要导入的列,在第一步中只能导入产品资料的基础数据,销售价格和库存记录在以下步骤中导入。

VFP数据导出到EXCEL技术.

VFP数据导出到EXCEL技术 我们都知道在 EXCEL 中有很多很多的计算公式、灵活多变的计算方式、方便快捷的图表处理、和功能强大的VBA 语言,可以说 EXCEL 可能是最好用的表格处理软件。我敢说:微软的产品中大概就 EXCEL 最好! 但是,怎样用 Foxpro 快速产生统计表,并将数据送到 Excel表格中,从而代替 Foxpro 的报表工具呢? 我们大家都知道,在 Visual Foxpro 3.0及以后版本中提供了一个调用Ole Automation 的函数 CREATEOBJECT,用该函数可以让 Visual Foxpro 很方便的和其它可以提供 Ole Automation 服务的程序进行通讯。而 Excel 更是一个标准的 Ole Automation 服务器程序,我们可以在前端将数据传送到后端的 Excel 服务程序,用后端服务程序进行表格处理,从而弥补 Visual Foxpro的不足。 由于历史原因,我们作报表都习惯用 Total、Count、Sum 或者直接在报表中工具中计算,速度最快的大概也就是 Total 了,但不知道还有多少人还在坚持使用 Total 命令进行计算,有没有更好的计算方法呢?当然有啦!我在实际使用中积累有一定的经验但愿能给各位起到小小的启发。 假设有一表:Table1 是一个人员档案,里面的表结构如下: -----字段名--类型及长度--------- 编号C,2 部门C,10 姓名C,10 性别C,2 出生日期 D 职务C,10 文化程度C,10 内容大概如下 TABLE1.DBF --------------------------------- 编号部门姓名性别出生日期职务文化程度 --------------------------------- 1 工程部张三男1971-01-11 工程师大学本科 2 销售部李四男1967-02-2 3 经理大学本科 3 工程部王武1954-03-1 4 技术员大学专科 4 总经理室赵洁雅女1975-04-0 5 秘书硕士研究生 5 销售部..1977-05-09 销售经理高中 6 工程部大文1969-03-30 总工程师大学专科 7 销售部..1961-10-10 销售经理大学专科 8 总经理室庄稼1961-10-10 总经理大学专科 当然实际的数据应该比这里多很多,要不还用统计干吗,我不过是举例说明而已。我不知道你们在使用 SQL 语句时有没有用使用函数的习惯,反正我是相

网页数据如何简单导出excel

https://www.doczj.com/doc/605890267.html, 网页数据如何简单导出excel 在浏览网页时,遇到我们需要的网页数据时,如文字、图片等,如何能简单的导出到Excel 中,方便在本地电脑中查看和编辑呢?当然是有办法的啦!下面就为大家介绍几种简单快速的将网页数据导出到Excel的方法,大家可以灵活运用。 一、通过浏览器导出网页数据 具体操作:打开某网页后,右键点击网页空白处,在下拉列表中选择“另存为”,然后在弹出的保存窗口中选择保存类型为“网页全部”。选择保存位置后确定,保存后就会自动保存两个文件,一个是网址,另一个是保存网页内容元素。 如何导出网页数据,以赶集网采集为例图1

https://www.doczj.com/doc/605890267.html, 二、通过网页数据采集器导出网页数据 先通过网页数据采集器,将网页数据采集下来,然后再导出为需要的格式即可。本文使用的是操作简单、功能强大的八爪鱼采集器。以下是一个八爪鱼采集并导出网页数据的完整示例。示例中采集的是赶集网上房产-商铺-深圳-南山分类下的所有商铺信息。 示例网站:https://www.doczj.com/doc/605890267.html,/fang6/nanshan/ 步骤1:创建采集任务 1)进入主界面,选择“自定义模式” 如何导出网页数据,以赶集网采集为例图2 2)将要采集的网址URL,复制粘贴到网址输入框中,点击“保存网址”

https://www.doczj.com/doc/605890267.html, 如何导出网页数据,以赶集网采集为例图3 步骤2:创建翻页循环 1)在页面右上角,打开“流程”,以展现出“流程设计器”和“定制当前操作”两个板块。将页面下拉到底部,点击“下一页”按钮,在右侧的操作提示框中,选择“循环点击下一页”

VFP全面控制EXCEL(完全版)

1.创建Excel对象 oExcel=Createobject("Excel.application") 2.添加新工作簿 oExcel.Workbooks.Add 3.设置第3个工作表为激活工作表 oExcel.Worksheets("sheet3").Activate 4.打开指定工作簿 oExcel.Workbooks.Open("c:\temp\ll.xls") 5.显示Excel窗口 oExcel.Visible=.T. 6.更改Excel标题栏 oExcel.Caption="VFP应用程序调用Microsoft Excel" 7.给单元格赋值 oExcel.cells(1,4).Value=XM(XM为数据库字段名) 8.设置指定列的宽度(单位:字符个数) oExcel.ActiveSheet.Columns(1).ColumnWidth=5 9.设置指定行的高度(单位:磅) oExcel.ActiveSheet.Rows(1).RowHeight=1&&(设定行高为1磅,1磅=0.035厘米) oExcel.ActiveSheet.Rows("50:100").RowHeight=1 &&设置第50行至100行的高度 10.在第18行之前插入分页符 oExcel.Worksheets("Sheet1").Rows(18).PageBreak=1 11.在第4列之前删除分页符 oExcel.ActiveSheet.Columns(4).PageBreak=0 12.指定边框线宽度(Borders参数如下) ole.ActiveSheet.Range("b3:d3").BorderS(2).Weight=3 13.设置四个边框线条的类型 oExcel.ActiveSheet.Range("b3:d3").BorderS(2).LineStyle=1 (其中Borders参数:1-左、2-右、3-顶、4-底、5-斜、6-斜/;LineStyle值:1与7-细实、2-细虚、4-点虚、9-双细实线) 14.设置页眉 oExcel.ActiveSheet.PageSetup.CenterHeader="报表1" 15.设置页眉(字体大小) oExcel.ActiveSheet.PageSetup.CenterHeader="&50报表1" &&'&'后面的50可以自定义,表示字体的大小 16.设置页脚 oExcel.ActiveSheet.PageSetup.CenterFooter="第&P页" 17.设置页脚(字体大小) oExcel.ActiveSheet.PageSetup.CenterFooter="&28第&P页" &&'&'后面的28可以自定义,表示字体的大小 18.设置页眉到顶端边距为2厘米 oExcel.ActiveSheet.PageSetup.HeaderMargin=2/0.035 19.设置页脚到底边距为3厘米 oExcel.ActiveSheet.PageSetup.FooterMargin=3/0.035

Foxpro 导入文件报错:无效的 Microsoft Excel 文件格式

Foxpro 导入文件报错:"无效的Microsoft Excel 文件格式" 症状:将一个 Microsoft Excel 版本 5.0 文件导入 FoxPro 时出现"无效的 Microsoft Excel 文件格式"错误信息。 症状拓展:如果使用的是 FoxPro 2.0 ,导入 Microsoft Excel 3.0 ,4.0 或 5.0 文件设置格式,则会收到错误信息"无效的 Excel 版本 2.0 文件"。 直接原因:FoxPro 2.0 仅可以导入 Microsoft Excel 2.0 文件。 FoxPro 2.5 for MS-DOS、Windows 和 Macintosh 可以导入 Microsoft Excel 2.0、 3.0 和 4.0 格式中的文件。 溯源:FoxPro 2.5 后,才发布 for MS-DOS 和 Windows 的开发。 FoxPro for Macintosh 是大约同时为 Microsoft Excel 5.0 for Windows 开发的。因此,支持导入 Microsoft Excel 5.0 格式的文件没有内置FoxPro 2.5。 Microsoft 已经确认这是Microsoft 产品中存在的问题并正在研究此问题,当它变得可用时,将发布新的信息的 Microsoft 知识库。 解决方案:要直接导入 Microsoft Excel 5.0 工作表,必须在 Microsoft Excel 中执行变通办法。这些变通办法有:保存 Microsoft Excel 5.0 文件作为一个 Microsoft Excel 4.0、3.0 或 2.0 格式的文件,再执行导入操作。或者将 Microsoft Excel 5.0 文件保存为一个DBF 格式文件。(要点:以 DBF3 文件格式保存;此外,Microsoft Excel 3.0、 4.0 和5.0 可以以 DBF4 文件格式保存文件。)FoxPro 可以打开这些两种文件格式之一。 参考文献: FoxPro for MS-DOS 和 Windows 语言参考,版本 2.5,页 L3-569 和 L3-570 FoxPro for Macintosh 语言参考,版本 2.5,页 468-469 Microsoft Excel 用户指南 1,版本 4.0、 60、 306 和 307 页

ABAP_EXCEL导出数据

使用EXCEL导出数据 要完成使用EXCEL导出数据,基本分为两布: 1 建立excel模版 2 在程序中整理要输出的数据,并完成最终的输出 1 建立excel模版 1.1 在本地建立一个excel 设置模版的格式,在本例中,模版格式如下: 1.2 使用Tcode:OROA,将模版导入SAP系统1. 2.1 输入Tcode:OROA

注:其他字段可以不填 1.2.2 导入模版 1.2.2.1 导入模版 Create——>standard.doc.types ——> table template 1.2.2.2 选择要导入的模版

1.2.2.3 输入模版信息——描述和语言 1.2.2.5 导入模版之后,在屏幕左上角会添加模版 2. 程序中整理数据,并调用模版输出2.1 整理数据,并调用屏幕 SELECT * FROM zlhjtest INTO CORRESPONDING FIELDS OF TABLE l_itab_stu. CALL SCREEN0100.

2.2 输出屏幕 2.2.1 输出屏幕之前,调用模版 SET PF-STATUS 'STAN1'. PERFORM create_basic_objects USING'''''''' document_name. PERFORM output_to_excel. 2.2.2 输出屏幕之后,根据用户选择做出反应 实现这些功能的的代码,如下: REPORT zlhjtest_abavn. TYPE-POOLS:slis,vrm,soi. TYPES:BEGIN OF l_hh, BSART LIKE T161-BSART, batxt TYPE t161t-batxt, END OF l_hh. DATA: ok_code TYPE sy-ucomm, save_ok TYPE sy-ucomm. DATA: flag TYPE c, initialized TYPE c, item_url(256) TYPE c, app TYPE vrm_id, excel(80) VALUE'Excel.Sheet', v_title1(60) TYPE c VALUE'制作人:李红娟'. DATA: rangeitem TYPE soi_range_item, ranges TYPE soi_range_list. DATA: excel_input TYPE soi_generic_table, excel_input_wa TYPE soi_generic_item. DATA: document_type(80) TYPE c, container TYPE REF TO cl_gui_custom_container, control TYPE REF TO i_oi_container_control, document TYPE REF TO i_oi_document_proxy, spreadshee TYPE REF TO i_oi_spreadsheet, error TYPE REF TO i_oi_error, errors TYPE REF TO i_oi_error OCCURS0WITH HEADER LINE. DATA: l_itab_stu TYPE TABLE OF t161t, l_wa_stu TYPE t161t.

韩小良 《Excel高效数据分析之道》

《Excel高效数据分析之道》 资深实战型Excel 培训讲师和应用解决方案专家韩小良面对浩瀚的数据,如何提炼信息,把需要的信息快速展示给客户和领导? 公司的经营状况和财务状况到底如何?预算执行情况到底如何?成本费用超支了吗? 销售收入、成本、费用是否正常?是否出现了异常情况?如何简便发现异常费用流向和预警机 制的建立? 如何即时发现资金流、销售、财务中的问题? 员工的构成分布情况如何?员工的流动情况如何?您是否为员工的不断离去伤透了脑筋而不知 其原因? 如何快速分析不同部门不同岗位等对公司的满意率,以便及时发现问题解决问题? 为什么产品的不合格率持续高位?怎样快速发现问题? 诸如此类的问题,等等,对任何一位管理者而言,是复杂而繁琐的,您想必一定很累、很烦了 吧! 您想要提高管理效率吗?想要进行科学的管理,而不是仅仅拍脑袋想问题、做决策吗? 等等…… 本课程将教会您利用Excel快速制作各种统计分析报表和图表的基本方法和技巧,还将使您的Excel使用水平提升到一个新的层次,使您的分析报告更加有说服力,更加引人注目! 课程宗旨: ●帮您树立一种正确高效使用Excel的基本理念和思路 ●为您提供一套实用高效的Excel技能和方法 课程目标: ●了解和掌握Excel数据统计分析的基本技能、技巧。 ●掌握利用Excel图表表达信息和观点的基本理念和方法。 ●掌握利用Excel绘制各种统计分析报表和图表的方法和技巧。 培训特点及收益: ●注重Excel在管理中的实际应用,培训内容紧密结合实际案例,利用大量的实际案例进行操练。 ●兼顾Excel使用方法技巧介绍和应用思路启发,注重点面结合。 ●注重强调动手实践,使每个学员有充分的动手机会,及时解决学习中的问题。 ●讲课认真、细致,辅导实验积极、耐心,使每个学员都能够掌握所讲的内容。 ●完善的课后服务,随时与老师联系,及时帮助企业学员解决实际工作中遇到的问题和难题。 课程特点: ●系统性:囊括利用Excel进行高效日常财务管理的各方面内容。 ●全面性:全面介绍了Excel工具的在日常管理中的典型应用,兼顾Excel使用方法技巧介绍和应用思路启 发,注重点面结合。 ●实用性:注重Excel在管理中的实际应用,培训内容紧密结合实际案例。精选数十个源自企业管理过程中 的典型案例,极具代表性和实用价值,反映了现实中企业需要解决的问题,具有更强的针对性。 ●示范性:注重强调动手实践,使每个学员有充分的动手机会,及时解决学习中的问题。在进行实例分析时 一步一步地递进,清晰易懂,既便于您了解财务管理决策分析过程,又使读者真正掌握Excel的强大功能。 ●细致性:讲课认真、细致,辅导实验积极、耐心,使每个学员都能够掌握所讲的内容。

VF中控制EXCEL的常用操作

VF中控制EXCEL的常用操作 myexcel=createobject('excel.application') &&创建一个对象 myexcel.visible=.t.&&可见 &&bookexcel=myexcel.workbooks.add bookexcel=myexcel.workbooks.open("C:\Documents and Settings\Administrator\桌面\学习\dd.xls") &&打开指定文件 nrows=bookexcel.worksheets('sheet1')&&打开工作表 UsedRange =https://www.doczj.com/doc/605890267.html,edRange&&返回工作表中可使用的区域,UsedRange表的属性 usedrange.columns.count&&计算共几列 r=usedrange.rows.count&&汇总行 c=usedrange.columns.count&&汇总列 with myexcel.application .sheets('sheet3').select .sheets.add&&添加一个工作表 https://www.doczj.com/doc/605890267.html, = 'ddddd'&&重命名表 endwith myexcel.Worksheets('sheet1').Activate&&选择表为当前工作表 myexcel.cells(1,1).value='sss'&&1,1处的值为 myexcel.activesheet.columns(2).columnwidth=15&&第2列的列宽设myexcel.activesheet.rows(2).rowheight=50&&设第2行的行高 myexcel.activesheet.rows(2).insert&&第2行前插入一行 myexcel.activesheet.columns(2).insert&&第2列前插入一列 myexcel.activesheet.Cells(1,1).Font.size=25&&设置1,1的字体大小myexcel.activesheet.Cells(1,1)https://www.doczj.com/doc/605890267.html,='黑体'&&设置字体 myexcel.activesheet.Cells(1,1).clear&&清除内容 myexcel.activesheet.range('A1:C2').select&&选择区域 myexcel.selection.merge &&选择区域合并单元格 myexcel.Range('a1').Formula='=sum(b2,b3,b4,b5)'&&在A1中键入一个公式 myexcel.range('a1').ClearContents myexcel.activesheet.Columns('A:B').Select&&整列选中 myexcel.Selection.NumberFormatLocal="@" &&设置选中的区域为字符型数据 myexcel.activesheet.rows(1).select myexcel.Selection.EntireRow.Delete&&删除选中的行 myexcel.Selection.columns(1).Delete&&删除第几的列 myexcel.workbooks.close&&关闭工作区

相关主题
文本预览
相关文档 最新文档