472 lines
12 KiB
C++
472 lines
12 KiB
C++
|
// DLG_User_Inport2.cpp : implementation file
|
|||
|
//
|
|||
|
|
|||
|
#include "stdafx.h"
|
|||
|
#include "corpsms.h"
|
|||
|
#include "DLG_User_Inport2.h"
|
|||
|
|
|||
|
#ifdef _DEBUG
|
|||
|
#define new DEBUG_NEW
|
|||
|
#undef THIS_FILE
|
|||
|
static char THIS_FILE[] = __FILE__;
|
|||
|
#endif
|
|||
|
|
|||
|
/////////////////////////////////////////////////////////////////////////////
|
|||
|
// DLG_User_Inport2 dialog
|
|||
|
|
|||
|
#include "FGAddress.h"
|
|||
|
#include "FPAddress.h"
|
|||
|
#include "MainFrm.h"
|
|||
|
#include "DLG_AddWarning.h"
|
|||
|
|
|||
|
DLG_User_Inport2::DLG_User_Inport2(CWnd* pParent /*=NULL*/)
|
|||
|
: CDialog(DLG_User_Inport2::IDD, pParent)
|
|||
|
{
|
|||
|
//{{AFX_DATA_INIT(DLG_User_Inport2)
|
|||
|
//}}AFX_DATA_INIT
|
|||
|
m_bInport = false;
|
|||
|
m_lAddressType = 0;
|
|||
|
m_bReMobile = false;
|
|||
|
m_bExportAll = false;
|
|||
|
memset(&m_szGroupID,0,sizeof(m_szGroupID));
|
|||
|
}
|
|||
|
|
|||
|
|
|||
|
void DLG_User_Inport2::DoDataExchange(CDataExchange* pDX)
|
|||
|
{
|
|||
|
CDialog::DoDataExchange(pDX);
|
|||
|
//{{AFX_DATA_MAP(DLG_User_Inport2)
|
|||
|
DDX_Control(pDX, IDC_USER_INPORT_REMOBILE, m_B_ReMobile);
|
|||
|
DDX_Control(pDX, IDC_USER_INPORT_RECORD_SPLIT, m_C_RecordSplit);
|
|||
|
DDX_Control(pDX, IDC_USER_INPORT_FIELD_SPLIT, m_C_FieldSplit);
|
|||
|
DDX_Control(pDX, IDC_USER_INPORT_S1, m_B_Tips);
|
|||
|
DDX_Control(pDX, IDC_USER_INPORT_FILENAME, m_E_FileName);
|
|||
|
DDX_Control(pDX, IDC_USER_INPORT_LIST, m_L_List);
|
|||
|
//}}AFX_DATA_MAP
|
|||
|
}
|
|||
|
|
|||
|
|
|||
|
BEGIN_MESSAGE_MAP(DLG_User_Inport2, CDialog)
|
|||
|
//{{AFX_MSG_MAP(DLG_User_Inport2)
|
|||
|
ON_BN_CLICKED(IDC_USER_INPORT_SELALL, OnUserInportSelall)
|
|||
|
ON_BN_CLICKED(IDC_USER_INPORT_CLEAR, OnUserInportClear)
|
|||
|
ON_BN_CLICKED(IDC_USER_INPORT_GETFILE, OnUserInportGetfile)
|
|||
|
//}}AFX_MSG_MAP
|
|||
|
END_MESSAGE_MAP()
|
|||
|
|
|||
|
/////////////////////////////////////////////////////////////////////////////
|
|||
|
// DLG_User_Inport2 message handlers
|
|||
|
|
|||
|
BOOL DLG_User_Inport2::OnInitDialog()
|
|||
|
{
|
|||
|
CDialog::OnInitDialog();
|
|||
|
|
|||
|
if ( !m_bInport )
|
|||
|
{
|
|||
|
this->SetWindowText(_T("<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ַ<EFBFBD><EFBFBD>(*.txt , *.csv)"));
|
|||
|
CWnd * pWnd = (CWnd*)GetDlgItem(IDOK);
|
|||
|
pWnd->SetWindowText(_T("<EFBFBD><EFBFBD> <20><>"));
|
|||
|
pWnd = (CWnd*)GetDlgItem(IDC_USER_INPORT_S2);
|
|||
|
pWnd->SetWindowText(_T("<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ֶ<EFBFBD><EFBFBD><EFBFBD>˳<EFBFBD><EFBFBD>(<28>϶<EFBFBD>ѡ<EFBFBD><D1A1>,<2C><><EFBFBD><EFBFBD>Ϊ<EFBFBD><CEAA><EFBFBD><EFBFBD><EFBFBD>ֶ<EFBFBD>)"));
|
|||
|
pWnd = (CWnd*)GetDlgItem(IDC_USER_INPORT_S1);
|
|||
|
pWnd->SetWindowText(_T("<EFBFBD><EFBFBD><EFBFBD><EFBFBD>txt/csv<73>ļ<EFBFBD><C4BC><EFBFBD>"));
|
|||
|
|
|||
|
m_C_FieldSplit.EnableWindow(false);
|
|||
|
m_C_RecordSplit.EnableWindow(false);
|
|||
|
}
|
|||
|
m_C_FieldSplit.SetCurSel(0);
|
|||
|
m_C_RecordSplit.SetCurSel(0);
|
|||
|
InitList();
|
|||
|
/*
|
|||
|
if ( !m_bPAddress || !m_bInport)
|
|||
|
{
|
|||
|
m_B_ReMobile.ShowWindow(SW_HIDE);
|
|||
|
}
|
|||
|
*/
|
|||
|
return TRUE; // return TRUE unless you set the focus to a control
|
|||
|
// EXCEPTION: OCX Property Pages should return FALSE
|
|||
|
}
|
|||
|
|
|||
|
void DLG_User_Inport2::OnOK()
|
|||
|
{
|
|||
|
BOOL b=User_Export();
|
|||
|
if (b)
|
|||
|
CDialog::OnOK();
|
|||
|
}
|
|||
|
|
|||
|
void DLG_User_Inport2::SetInport(CAdoRecordSet * pAdoRS,const TCHAR * szGroupID,long lAddressType,BOOL bExportAll)
|
|||
|
{
|
|||
|
m_lAddressType= lAddressType; //ͨѶ¼<D1B6><C2BC><EFBFBD><EFBFBD>,0-users,1-paddress,2-gaddress
|
|||
|
m_bExportAll=bExportAll;
|
|||
|
m_pAdoRS = pAdoRS;
|
|||
|
_tcscpy(m_szGroupID,szGroupID);
|
|||
|
|
|||
|
}
|
|||
|
|
|||
|
void DLG_User_Inport2::InitList()
|
|||
|
{
|
|||
|
m_L_List.Init(true,-1,-1,-1);
|
|||
|
m_L_List.InsertColumn( 0 , _T("˳<EFBFBD><EFBFBD>") , LVCFMT_LEFT , 40 , 0);
|
|||
|
m_L_List.InsertColumn( 1 , _T(" <20>ֶ<EFBFBD><D6B6><EFBFBD>") , LVCFMT_LEFT , 120 , 1);
|
|||
|
m_L_List.SetTextColor( RGB(0,0,255) );
|
|||
|
if ( m_lAddressType>0 )
|
|||
|
{
|
|||
|
TCHAR * pItem[] =
|
|||
|
{
|
|||
|
_T("<EFBFBD><EFBFBD> <20><>"),
|
|||
|
_T("<EFBFBD><EFBFBD> <20><>"),
|
|||
|
_T("<EFBFBD><EFBFBD> <20><>"),
|
|||
|
_T("<EFBFBD><EFBFBD> <20><>"),
|
|||
|
_T("<EFBFBD><EFBFBD> ˾"),
|
|||
|
_T("ְ <20><>"),
|
|||
|
_T("<EFBFBD><EFBFBD> ַ"),
|
|||
|
_T("<EFBFBD><EFBFBD> <20><>"),
|
|||
|
_T("<EFBFBD><EFBFBD> <20><>"),
|
|||
|
_T("<EFBFBD><EFBFBD> <20><>"),
|
|||
|
_T("Email"),
|
|||
|
_T("QQ"),
|
|||
|
_T("<EFBFBD><EFBFBD> ע"),
|
|||
|
};
|
|||
|
TCHAR Buf[256];
|
|||
|
|
|||
|
for ( int i = 0 ; i<13 ; i++ )
|
|||
|
{
|
|||
|
m_L_List.InsertItem( i , _itot(i+1,Buf,10) );
|
|||
|
m_L_List.SetItemText(i , 1 , pItem[i] );
|
|||
|
m_L_List.SetItemData(i , i ); //<2F><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>Ϊ<EFBFBD><CEAA>˳<EFBFBD><CBB3><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ڴ<EFBFBD><DAB4><EFBFBD>
|
|||
|
}
|
|||
|
}
|
|||
|
else
|
|||
|
{
|
|||
|
TCHAR * pItem[] =
|
|||
|
{
|
|||
|
_T("<EFBFBD><EFBFBD> <20><>"),
|
|||
|
_T("<EFBFBD><EFBFBD> <20><>"),
|
|||
|
_T("<EFBFBD><EFBFBD> <20><>"),
|
|||
|
_T("<EFBFBD><EFBFBD> <20><>"),
|
|||
|
_T("ְ <20><>"),
|
|||
|
_T("<EFBFBD><EFBFBD> <20><>"),
|
|||
|
_T("<EFBFBD><EFBFBD> <20><>"),
|
|||
|
_T("<EFBFBD><EFBFBD> <20><>"),
|
|||
|
_T("Email"),
|
|||
|
_T("QQ"),
|
|||
|
_T("<EFBFBD><EFBFBD> ע"),
|
|||
|
};
|
|||
|
TCHAR Buf[256];
|
|||
|
|
|||
|
for ( int i = 0 ; i<11 ; i++ )
|
|||
|
{
|
|||
|
m_L_List.InsertItem( i , _itot(i+1,Buf,10) );
|
|||
|
m_L_List.SetItemText(i , 1 , pItem[i] );
|
|||
|
m_L_List.SetItemData(i , i ); //<2F><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>Ϊ<EFBFBD><CEAA>˳<EFBFBD><CBB3><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ڴ<EFBFBD><DAB4><EFBFBD>
|
|||
|
}
|
|||
|
}
|
|||
|
m_L_List.CheckAll();
|
|||
|
m_L_List.NoverCheck();
|
|||
|
m_L_List.ReShowSort();
|
|||
|
}
|
|||
|
|
|||
|
void DLG_User_Inport2::OnUserInportSelall()
|
|||
|
{
|
|||
|
m_L_List.CheckAll();
|
|||
|
}
|
|||
|
|
|||
|
void DLG_User_Inport2::OnUserInportClear()
|
|||
|
{
|
|||
|
m_L_List.ClearAll();
|
|||
|
}
|
|||
|
|
|||
|
BOOL DLG_User_Inport2::User_Export()
|
|||
|
{
|
|||
|
long lItemCount = m_L_List.GetItemCount();
|
|||
|
long lExPortItem[50];memset(&lExPortItem,0,sizeof(lExPortItem));
|
|||
|
for ( int j=0 ; j < 50 ; j++ ) lExPortItem[j] = -1;
|
|||
|
long lCheckCount = 0;
|
|||
|
for ( int i=0 ; i<lItemCount ; i++ )
|
|||
|
{
|
|||
|
if ( m_L_List.GetCheck(i) )
|
|||
|
{
|
|||
|
lExPortItem[lCheckCount] = m_L_List.GetItemData(i) ;
|
|||
|
lCheckCount ++;
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
if ( lCheckCount <=0 )
|
|||
|
{
|
|||
|
if ( m_bInport )
|
|||
|
MessageBox( _T("<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ߵ<EFBFBD><EFBFBD>ֶ<EFBFBD><EFBFBD>б<EFBFBD><EFBFBD><EFBFBD>ѡ<EFBFBD><EFBFBD>һ<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ֶΡ<EFBFBD>") , _T("ѡ<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>") , MB_OK|MB_ICONWARNING );
|
|||
|
else
|
|||
|
MessageBox( _T("<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ߵ<EFBFBD><EFBFBD>ֶ<EFBFBD><EFBFBD>б<EFBFBD><EFBFBD><EFBFBD>ѡ<EFBFBD><EFBFBD>һ<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ֶΡ<EFBFBD>") , _T("ѡ<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>") , MB_OK|MB_ICONWARNING );
|
|||
|
return false;
|
|||
|
}
|
|||
|
TCHAR szFileName[512];
|
|||
|
m_E_FileName.GetWindowText( szFileName , sizeof(szFileName) );
|
|||
|
if ( _tcslen(AllTrim(szFileName)) <=0 )
|
|||
|
{
|
|||
|
if ( m_bInport )
|
|||
|
MessageBox( _T("<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>뵼<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ļ<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>") , _T("<EFBFBD><EFBFBD><EFBFBD><EFBFBD>") , MB_OK|MB_ICONWARNING );
|
|||
|
else
|
|||
|
MessageBox( _T("<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>뵼<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ļ<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>") , _T("<EFBFBD><EFBFBD><EFBFBD><EFBFBD>") , MB_OK|MB_ICONWARNING );
|
|||
|
m_E_FileName.SetFocus();
|
|||
|
return false;
|
|||
|
}
|
|||
|
|
|||
|
CFile fTalk;
|
|||
|
if ( !fTalk.Open( szFileName , CFile::modeReadWrite|CFile::modeCreate ) )
|
|||
|
{
|
|||
|
TCHAR Buf[512];
|
|||
|
_stprintf( Buf , _T("<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ļ<EFBFBD>:%s\n<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>!") , szFileName );
|
|||
|
MessageBox( Buf , _T("<EFBFBD><EFBFBD><EFBFBD><EFBFBD>") , MB_ICONWARNING|MB_OK );
|
|||
|
return false;
|
|||
|
}
|
|||
|
|
|||
|
TCHAR Buf[1024]={0};
|
|||
|
TCHAR Buf2[256]={0};
|
|||
|
long lRecnCount= 0; //<2F>ܼ<EFBFBD>¼<EFBFBD><C2BC>
|
|||
|
long lFileSize = 0; //<2F>ļ<EFBFBD><C4BC><EFBFBD><EFBFBD>ֽ<EFBFBD><D6BD><EFBFBD>
|
|||
|
long lBufLen = 0;
|
|||
|
#ifdef UNICODE
|
|||
|
char szTempA[4096];
|
|||
|
#endif
|
|||
|
if ( m_B_ReMobile.GetCheck() ) //<2F><><EFBFBD><EFBFBD><EFBFBD>ֶ<EFBFBD>
|
|||
|
{
|
|||
|
for( int j = 0 ; j< lCheckCount ; j++ ) //<2F><><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ѡ<EFBFBD>е<EFBFBD><D0B5>ֶΣ<D6B6>ȡͨѶ¼<D1B6><C2BC><EFBFBD>ݽ<EFBFBD><DDBD>б<EFBFBD><D0B1>档
|
|||
|
{
|
|||
|
memset(Buf2 , 0 , sizeof(Buf2) );
|
|||
|
long lItemJ = lExPortItem[j];
|
|||
|
if ( m_lAddressType==0 && lItemJ>=4 )
|
|||
|
lItemJ++;
|
|||
|
if ( m_lAddressType==0 && lItemJ>=6 )
|
|||
|
lItemJ++;
|
|||
|
switch( lItemJ )
|
|||
|
{
|
|||
|
case 0: //<2F><><EFBFBD><EFBFBD>
|
|||
|
_tcscpy(Buf2,_T("<EFBFBD><EFBFBD> <20><>"));
|
|||
|
break;
|
|||
|
case 1: //<2F><> <20><>
|
|||
|
_tcscpy(Buf2,_T("<EFBFBD><EFBFBD> <20><>"));
|
|||
|
break;
|
|||
|
case 2: //Sex
|
|||
|
_tcscpy(Buf2,_T("<EFBFBD><EFBFBD> <20><>"));
|
|||
|
break;
|
|||
|
case 3: //<2F><> <20><>
|
|||
|
_tcscpy(Buf2,_T("<EFBFBD><EFBFBD> <20><>"));
|
|||
|
break;
|
|||
|
case 4: //<2F><> ˾
|
|||
|
_tcscpy(Buf2,_T("<EFBFBD><EFBFBD> ˾"));
|
|||
|
break;
|
|||
|
case 5: //ְ <20><>
|
|||
|
_tcscpy(Buf2,_T("ְ <20><>"));
|
|||
|
break;
|
|||
|
case 6: //<2F><> ַ
|
|||
|
_tcscpy(Buf2,_T("<EFBFBD><EFBFBD> ַ"));
|
|||
|
break;
|
|||
|
case 7: //<2F><> <20><>
|
|||
|
_tcscpy(Buf2,_T("<EFBFBD><EFBFBD> <20><>"));
|
|||
|
break;
|
|||
|
case 8: //<2F><> <20><>
|
|||
|
_tcscpy(Buf2,_T("<EFBFBD><EFBFBD> <20><>"));
|
|||
|
break;
|
|||
|
case 9: //<2F><> <20><>
|
|||
|
_tcscpy(Buf2,_T("<EFBFBD><EFBFBD> <20><>"));
|
|||
|
break;
|
|||
|
case 10: //Email
|
|||
|
_tcscpy(Buf2,_T("Email"));
|
|||
|
break;
|
|||
|
case 11: //QQ
|
|||
|
_tcscpy(Buf2,_T("QQ"));
|
|||
|
break;
|
|||
|
case 12: //<2F><> ע
|
|||
|
_tcscpy(Buf2,_T("<EFBFBD><EFBFBD> ע"));
|
|||
|
break;
|
|||
|
}
|
|||
|
_tcscat(Buf , Buf2 );
|
|||
|
if ( j < lCheckCount-1 ) //<2F><><EFBFBD><EFBFBD>һ<EFBFBD><D2BB><EFBFBD><EFBFBD><EFBFBD>ü<EFBFBD>","<22><>
|
|||
|
_tcscat(Buf , _T(",") );
|
|||
|
}
|
|||
|
_tcscat(Buf , _T("\r\n") ); //<2F><><EFBFBD><EFBFBD>
|
|||
|
#ifdef UNICODE
|
|||
|
CAdoRecordSet::Ado_W2A(Buf,szTempA);
|
|||
|
lBufLen = strlen(szTempA);
|
|||
|
fTalk.Write( szTempA , lBufLen );
|
|||
|
#else
|
|||
|
lBufLen = _tcslen(Buf);
|
|||
|
fTalk.Write( Buf , lBufLen );
|
|||
|
#endif
|
|||
|
}
|
|||
|
|
|||
|
CString strSelect;
|
|||
|
CString strTable = _T("paddress");
|
|||
|
if ( m_lAddressType==0 )
|
|||
|
strTable = _T("users");
|
|||
|
if ( m_lAddressType==2 )
|
|||
|
strTable = _T("gaddress");
|
|||
|
if ( m_bExportAll )
|
|||
|
{
|
|||
|
strSelect.Format( _T("select * from %s where UserType='1' order by GroupID"),strTable ); //<2F><><EFBFBD>Ҵ<EFBFBD><D2B4><EFBFBD><EFBFBD>µ<EFBFBD><C2B5>û<EFBFBD>
|
|||
|
}
|
|||
|
else
|
|||
|
{
|
|||
|
if ( _tcslen(m_szGroupID)<=0 ) //<2F><><EFBFBD><EFBFBD><EFBFBD>Ǹ<EFBFBD><C7B8><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
|||
|
strSelect.Format( _T("select * from %s where GroupID is null or len(GroupID)=0 and UserType='1' ") ,strTable); //<2F><><EFBFBD>Ҵ<EFBFBD><D2B4><EFBFBD><EFBFBD>µ<EFBFBD><C2B5>û<EFBFBD>
|
|||
|
else
|
|||
|
strSelect.Format( _T("Select * from %s where GroupID='%s' AND UserType='1' ") ,strTable, m_szGroupID ); //<2F><><EFBFBD>Ҵ<EFBFBD><D2B4><EFBFBD><EFBFBD>µ<EFBFBD><C2B5>û<EFBFBD>
|
|||
|
}
|
|||
|
BOOL b = m_pAdoRS->Open( strSelect );
|
|||
|
long lCount = m_pAdoRS->GetRecordCount();
|
|||
|
if ( b && lCount )
|
|||
|
{
|
|||
|
COleDateTime t;
|
|||
|
m_pAdoRS->MoveFirst();
|
|||
|
|
|||
|
while(!m_pAdoRS->IsEOF() )
|
|||
|
{
|
|||
|
memset(Buf , 0 , sizeof(Buf) );
|
|||
|
for( int j = 0 ; j< lCheckCount ; j++ ) //<2F><><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ѡ<EFBFBD>е<EFBFBD><D0B5>ֶΣ<D6B6>ȡͨѶ¼<D1B6><C2BC><EFBFBD>ݽ<EFBFBD><DDBD>б<EFBFBD><D0B1>档
|
|||
|
{
|
|||
|
memset(Buf2 , 0 , sizeof(Buf2) );
|
|||
|
long lItemJ = lExPortItem[j];
|
|||
|
if ( m_lAddressType==0 && lItemJ>=4 )
|
|||
|
lItemJ++;
|
|||
|
if ( m_lAddressType==0 && lItemJ>=6 )
|
|||
|
lItemJ++;
|
|||
|
switch( lItemJ )
|
|||
|
{
|
|||
|
case 0: //<2F><><EFBFBD><EFBFBD>
|
|||
|
m_pAdoRS->GetCollect( _T("Name") , Buf2 );
|
|||
|
break;
|
|||
|
case 1: //<2F><> <20><>
|
|||
|
m_pAdoRS->GetCollect( _T("NickName") , Buf2 );
|
|||
|
break;
|
|||
|
case 2: //Sex
|
|||
|
m_pAdoRS->GetCollect( _T("Sex") , Buf2 );
|
|||
|
break;
|
|||
|
case 3: //<2F><> <20><>
|
|||
|
m_pAdoRS->GetCollect( _T("Birthday") , t );
|
|||
|
if ( t.GetStatus() == COleDateTime::valid )
|
|||
|
_stprintf( Buf2 , _T("%04d-%02d-%02d") , t.GetYear(),t.GetMonth(),t.GetDay() );
|
|||
|
else
|
|||
|
memset(Buf2 , 0 , sizeof(Buf2));
|
|||
|
break;
|
|||
|
case 4: //<2F><> ˾
|
|||
|
m_pAdoRS->GetCollect( _T("Ltd") , Buf2 );
|
|||
|
break;
|
|||
|
case 5: //ְ <20><>
|
|||
|
m_pAdoRS->GetCollect( _T("Job") , Buf2 );
|
|||
|
break;
|
|||
|
case 6: //<2F><> ַ
|
|||
|
m_pAdoRS->GetCollect( _T("Addr") , Buf2 );
|
|||
|
break;
|
|||
|
case 7: //<2F><> <20><>
|
|||
|
m_pAdoRS->GetCollect( _T("Mobile") , Buf2 );
|
|||
|
break;
|
|||
|
case 8: //<2F><> <20><>
|
|||
|
m_pAdoRS->GetCollect( _T("Tel") , Buf2 );
|
|||
|
break;
|
|||
|
case 9: //<2F><> <20><>
|
|||
|
m_pAdoRS->GetCollect( _T("Fax") , Buf2 );
|
|||
|
break;
|
|||
|
case 10: //Email
|
|||
|
m_pAdoRS->GetCollect( _T("Email") , Buf2 );
|
|||
|
break;
|
|||
|
case 11: //QQ
|
|||
|
m_pAdoRS->GetCollect( _T("QQ") , Buf2 );
|
|||
|
break;
|
|||
|
case 12: //<2F><> ע
|
|||
|
m_pAdoRS->GetCollect( _T("BZ") , Buf2 );
|
|||
|
break;
|
|||
|
}
|
|||
|
_tcscat(Buf , Buf2 );
|
|||
|
if ( j < lCheckCount-1 ) //<2F><><EFBFBD><EFBFBD>һ<EFBFBD><D2BB><EFBFBD><EFBFBD><EFBFBD>ü<EFBFBD>","<22><>
|
|||
|
_tcscat(Buf , _T(",") );
|
|||
|
}
|
|||
|
_tcscat(Buf , _T("\r\n") ); //<2F><><EFBFBD><EFBFBD>
|
|||
|
#ifdef UNICODE
|
|||
|
CAdoRecordSet::Ado_W2A(Buf,szTempA);
|
|||
|
lBufLen = strlen(szTempA);
|
|||
|
fTalk.Write( szTempA , lBufLen );
|
|||
|
#else
|
|||
|
lBufLen = _tcslen(Buf);
|
|||
|
fTalk.Write( Buf , lBufLen );
|
|||
|
#endif
|
|||
|
lRecnCount++; //ȡ<><C8A1><EFBFBD>ܼ<EFBFBD>¼<EFBFBD><C2BC>
|
|||
|
lFileSize = lFileSize + lBufLen ; //ȡ<><C8A1><EFBFBD><EFBFBD><EFBFBD>ֽ<EFBFBD><D6BD><EFBFBD>
|
|||
|
m_pAdoRS->MoveNext();
|
|||
|
}
|
|||
|
}
|
|||
|
fTalk.Close();
|
|||
|
this->EndWaitCursor();
|
|||
|
_stprintf(Buf , _T("<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>б<EFBFBD><EFBFBD>ɹ<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>£<EFBFBD>\n<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ļ<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>:TXT\n<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>¼<EFBFBD><EFBFBD>:%d\n<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ֽ<EFBFBD><EFBFBD><EFBFBD>:%d\n<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ļ<EFBFBD><EFBFBD><EFBFBD>:%s") , lRecnCount , lFileSize , szFileName);
|
|||
|
MessageBox( Buf , _T("<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ɹ<EFBFBD>"),MB_OK|MB_ICONINFORMATION );
|
|||
|
return true;
|
|||
|
}
|
|||
|
|
|||
|
void DLG_User_Inport2::OnUserInportGetfile()
|
|||
|
{
|
|||
|
#define FILE_FILTER_TEXT \
|
|||
|
TEXT("txt<EFBFBD>ı<EFBFBD><EFBFBD>ļ<EFBFBD> (*.txt)\0*.txt\0")\
|
|||
|
TEXT("Excel csv <20>ļ<EFBFBD> (*.csv)\0*.csv\0")\
|
|||
|
TEXT("<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ļ<EFBFBD> (*.*)\0*.*;\0\0")
|
|||
|
|
|||
|
if ( m_bInport )
|
|||
|
{
|
|||
|
TCHAR szFile[ 256 ];
|
|||
|
TCHAR szFileB[ 256 ];
|
|||
|
*szFileB = NULL;
|
|||
|
_stprintf( szFile , _T("Address.txt") );
|
|||
|
|
|||
|
OPENFILENAME sOpen;
|
|||
|
sOpen.lStructSize = sizeof( sOpen );
|
|||
|
sOpen.hwndOwner = this->m_hWnd ;
|
|||
|
sOpen.Flags = OFN_EXPLORER|OFN_OVERWRITEPROMPT|OFN_HIDEREADONLY;
|
|||
|
sOpen.lpstrFilter = FILE_FILTER_TEXT;
|
|||
|
sOpen.lpstrDefExt = _T("txt");
|
|||
|
sOpen.lpstrCustomFilter = NULL;
|
|||
|
sOpen.nMaxCustFilter = 0;
|
|||
|
sOpen.lpstrFile = szFile;
|
|||
|
sOpen.nMaxFile = sizeof( szFile );
|
|||
|
sOpen.lpstrFileTitle = szFileB;
|
|||
|
sOpen.nMaxFileTitle = sizeof( szFileB );
|
|||
|
sOpen.lpstrInitialDir = NULL;
|
|||
|
sOpen.lpstrTitle = _T("<EFBFBD><EFBFBD><EFBFBD>뷢<EFBFBD><EFBFBD><EFBFBD>б<EFBFBD><EFBFBD><EFBFBD><EFBFBD>ļ<EFBFBD>");
|
|||
|
if ( ::GetOpenFileName( &sOpen ) )
|
|||
|
{
|
|||
|
m_E_FileName.SetWindowText(sOpen.lpstrFile);
|
|||
|
return ;
|
|||
|
}
|
|||
|
}
|
|||
|
else
|
|||
|
{
|
|||
|
TCHAR szFile[ 256 ];
|
|||
|
TCHAR szFileB[ 256 ];
|
|||
|
*szFileB = NULL;
|
|||
|
_stprintf( szFile , _T("Address") );
|
|||
|
if ( m_strName.GetLength()>0 )
|
|||
|
_stprintf( szFile ,m_strName );
|
|||
|
|
|||
|
OPENFILENAME sOpen;
|
|||
|
sOpen.lStructSize = sizeof( sOpen );
|
|||
|
sOpen.hwndOwner = this->m_hWnd ;
|
|||
|
sOpen.Flags = OFN_EXPLORER|OFN_OVERWRITEPROMPT|OFN_HIDEREADONLY;
|
|||
|
sOpen.lpstrFilter = FILE_FILTER_TEXT;
|
|||
|
sOpen.lpstrDefExt = _T("csv");
|
|||
|
sOpen.lpstrCustomFilter = NULL;
|
|||
|
sOpen.nMaxCustFilter = 0;
|
|||
|
sOpen.lpstrFile = szFile;
|
|||
|
sOpen.nMaxFile = sizeof( szFile );
|
|||
|
sOpen.lpstrFileTitle = szFileB;
|
|||
|
sOpen.nMaxFileTitle = sizeof( szFileB );
|
|||
|
sOpen.lpstrInitialDir = NULL;
|
|||
|
sOpen.lpstrTitle = _T("ѡ<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>б<EFBFBD><EFBFBD><EFBFBD><EFBFBD>ļ<EFBFBD>");
|
|||
|
if ( ::GetSaveFileName( &sOpen ) )
|
|||
|
{
|
|||
|
m_E_FileName.SetWindowText(sOpen.lpstrFile);
|
|||
|
}
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
void DLG_User_Inport2::SetOutportName(CString strName)
|
|||
|
{
|
|||
|
m_strName = strName;
|
|||
|
}
|