|
2006年11月24日
/Files/rttw/Excel.zip
本程序用来将多个excel 报表合并成一个文件,取第一个文件的前n 行做为报表的题头,n 可自定义。
1.支持直接添加多个文件
2.支持直接添加某个文件夹下面的所有excel文件
3 支持直接将excel文件拖放到程序界面
4.可以单选或多选记录然后用右键删除
5.可以定义excel表头记录数
6.本版本暂时只支持合并Excel文件的第一个sheet
7.双击某条记录可直接删除
8.开发环境 VC6+OFFICE2007,其他版本OFFICE有可能不兼容
北京寄来的件,已经第四天了,打电话到广州中转,说还没到广州,竟然让我自己打电话到北京去问.再说了两句竟然挂了我的电话.简直是垃圾啊.客户打电话上来的有问题的件应该是快递公司内部处理解决吧,竟然让客户自己去跟踪??奉劝大家以后千万不要用申通快递,切记且记
[root@linux-test188 ~]# cdrecord -scanbus Cdrecord-Clone 2.01-dvd (i686-pc-linux-gnu) Copyright (C) 1995-2004 J枚rg Schilling Note: This version is an unofficial (modified) version with DVD support Note: and therefore may have bugs that are not present in the original. Note: Please send bug reports or support requests to http://bugzilla.redhat.com/bugzilla Note: The author of cdrecord should not be bothered with problems in this version. scsidev: 'ATA' devname: 'ATA' scsibus: -2 target: -2 lun: -2 Linux sg driver version: 3.5.27 Using libscg version 'schily-0.8'. cdrecord: Warning: using inofficial libscg transport code version (schily - Red Hat-scsi-linux-sg.c-1.83-RH '@(#)scsi-linux-sg.c 1.83 04/05/20 Copyright 1997 J. Schilling'). scsibus1: 1,0,0 100) 'HL-DT-ST' 'CD-RW GCE-8400B ' '1.02' Removable CD-ROM 1,1,0 101) * 1,2,0 102) * 1,3,0 103) * 1,4,0 104) * 1,5,0 105) * 1,6,0 106) * 1,7,0 107) * [root@linux-test188 ~]# cdrecord -v speed=8 dev=1,0,0 test.iso
[root@linux-test188 ~]# mkisofs -r -o cd.iso -m temp ./tempfiles
select * from a,b where a.id=b.id(+); select * from a left join b on a.id=b.id;
很多资料说上面两个语句的效果是一样的,实际上今天经过测试发现两者的执行计划大不相同(查询结果是一样的); 至于为什么会这样,暂时没有深究,手头的一个例子表明按照第一种写法的效率会高,或许其他的例子结果不一样,等有时间的时候再测试一下吧.
同样的一条语句,一条是在pl/sql里面组装成sql之后提交执行,另外一条是用pro*c程序后绑定执行,没想到执行策略和效率天差地别。看来做什么事都不能想当然,要细心学习才行。保留此条语句以做纪念:
select * from (select /*+ INDEX(A IDX_HISBUFAREJOUR_ACCOUNT) +*/ a.*, f.sort_name from hs_his.hisbufarejour a, hs_fund.faresort f where (((((((a.fare_sort = f.fare_sort and a.client_id = :b0) and (:b1 = 0 or a.fund_account = :b2)) and a.init_date >= :b3) and a.init_date <= :b4) and (trim(:b5) is null or instr(((',' || :b6) || ','), ((',' || a.exchange_type) || ',')) > 0)) and (trim(:b7) is null or instr(((',' || :b8) || ','), ((',' || a.money_type) || ',')) > 0)) and (trim(:b9) is null or a.position_str > :b10)) order by a.position_str) where rownum <= :b11
b0:130330000516 b1:595995 b2:595995 b3:20061221 b4:20061221 b5:1 b6:1 b7:2 b8:2 b9: b10: b11:30
vc的对话框中,如果直接用picturebox作为对话框的背景,则其他控件会被挡住。经过高手指点,重载了WM_ERASEBKGND消息处理函数,很少的解决了这个问题。而且按照这个思路,可以很方便的为dialog增加动态的skin:
声明消息处理函数:
// Generated message map functions //{{AFX_MSG(Input) afx_msg BOOL OnEraseBkgnd(CDC* pDC); afx_msg void OnButtonOk(); afx_msg void OnLButtonDblClk(UINT nFlags, CPoint point); afx_msg void OnPaint(); //}}AFX_MSG DECLARE_MESSAGE_MAP()
声明消息循环: BEGIN_MESSAGE_MAP(Input, CDialog) //{{AFX_MSG_MAP(Input) ON_BN_CLICKED(IDC_BUTTON_OK, OnButtonOk) ON_WM_LBUTTONDBLCLK() ON_WM_PAINT() ON_WM_ERASEBKGND() //}}AFX_MSG_MAP END_MESSAGE_MAP()
实现: BOOL Input::OnEraseBkgnd(CDC* pDC) {
if(m_hBmp) { BITMAP bm; GetObject(m_hBmp,sizeof(bm),&bm); HDC hMemdc=CreateCompatibleDC(pDC->m_hDC); if(hMemdc) { HBITMAP hOldBmp=(HBITMAP)SelectObject(hMemdc,m_hBmp); if(hOldBmp) { BitBlt(pDC->m_hDC,0,0,bm.bmWidth,bm.bmHeight,hMemdc,0,0,SRCCOPY); SelectObject(hMemdc,hOldBmp); DeleteDC(hMemdc); DeleteObject(hOldBmp); return TRUE; } else DeleteDC(hMemdc); } } return CDialog::OnEraseBkgnd(pDC); }
今天系统莫明其妙的故障,以前用的好好的客户信息汇总统计突然出现异常,查看日志显示oracle的sql语句异常. 跟踪调试后台发现问题出现在sprintf语句上面,sql预定义 char[8000],然后用sprintf来格式化,结果当语句的数据超过8000的时候就不能正常处理了. google了一下:
众所周知,sprintf不能检查目标字符串的长度,可能造成众多安全问题,所以都会推荐使用snprintf.
snprintf(_snprintf)的声明是这样的
int _snprintf( char *buffer, size_t count, const char *format [, argument] ... );
If len < count, then len characters are stored in buffer, a null-terminator is appended, and len is returned.
If len = count, then len characters are stored in buffer, no null-terminator is appended, and len is returned.
If len > count, then count characters are stored in buffer, no null-terminator is appended, and a negative value is returned.
最常见的错误用法有: 1. char sa[256]={0}; _snprintf(sa,sizeof(sa),"%s",sb); //错误原因:当sb的长度>=256的时候,sa将没有'\0'结尾
2. char sa[256]; _snprintf(sa,sizeof(sa)-1,"%s",sb); //错误原因:当sb的长度>=255的时候,sa将没有'\0'结尾,忘记给sa初始化
3. char sa[256]; _snprintf(sa,sizeof(sa)-1,"%s",sb); sa[sizeof(sa)]=0; //错误原因:最后一行数组越界
正确的用法 1. //推荐用法 char sa[256]; sa[sizeof(sa)-1]=0; _snprintf(sa,sizeof(sa),"%s",sb); if(sa[sizeof(sa)-1]!=0) { printf("warning:string will be truncated"); sa[sizeof(sa)-1]=0; }
2. char sa[256]={0}; int result = _snprintf(sa,sizeof(sa),"%s",sb); if(result==sizeof(sa) || result<0) { printf("warning:sting will be truncated"); sa[sizeof(sa)-1]=0; }
首先定义消息:
#define POST_DATA_START WM_USER+1 #define POST_DATA_END WM_USER+2 #define RECEIVE_DATA_START WM_USER+3 #define RECEIVE_DATA_END WM_USER+4 #define THREAD_START WM_USER+5 #define THREAD_END WM_USER+6 #define TASK_START WM_USER+7 #define TASK_END WM_USER+8 #define TASK_IDEL WM_USER+9
声明处理函数 //{{AFX_MSG(CMyDlg) ........ afx_msg void OnPostDataStart(WPARAM wParam, LPARAM lParam); afx_msg void OnPostDataEnd(WPARAM wParam, LPARAM lParam); afx_msg void OnReceiveDataStart(WPARAM wParam, LPARAM lParam); afx_msg void OnReceiveDataEnd(WPARAM wParam, LPARAM lParam); afx_msg void OnThreadStart(WPARAM wParam, LPARAM lParam); afx_msg void OnThreadEnd(WPARAM wParam, LPARAM lParam); afx_msg void OnTaskStart(WPARAM wParam, LPARAM lParam); afx_msg void OnTaskEnd(WPARAM wParam, LPARAM lParam); afx_msg void OnTaskIdel(WPARAM wParam, LPARAM lParam); //}}AFX_MSG DECLARE_MESSAGE_MAP() 注意所有函数声明都要在 DECLARE_MESSAGE_MAP()前面
绑定消息和处理函数: BEGIN_MESSAGE_MAP(CMyDlg, CDialog) //{{AFX_MSG_MAP(CMyDlg) ON_MESSAGE(POST_DATA_START,OnPostDataStart) ON_MESSAGE(POST_DATA_END,OnPostDataEnd) ON_MESSAGE(POST_DATA_START,OnReceiveDataStart) ON_MESSAGE(RECEIVE_DATA_START,OnReceiveDataEnd) ON_MESSAGE(RECEIVE_DATA_END,OnThreadStart) ON_MESSAGE(THREAD_START,OnThreadEnd) ON_MESSAGE(TASK_END,OnTaskStart) ON_MESSAGE(TASK_START,OnTaskEnd) ON_MESSAGE(TASK_IDEL,OnTaskIdel)
//}}AFX_MSG_MAP END_MESSAGE_MAP()
当然最后还要完成函数实体
|