Page 1 sur 1

Export vers Excel

MessagePublié: 25 Mai 2003 à 19:18
par WKTFE
Bonsoir Comment exporter les données présentées par une vue vers un fichier Excel ou une table Access ?L'export vers Lotus123 est limité à 8000 enregistrements.Merci

Re: Export vers Excel

MessagePublié: 25 Mai 2003 à 21:02
par Stephane Maillard
Bonjour,Le code suivant devrait vous convenir :Sub Initialize Dim Session As New NotesSession Dim db As NotesDatabase Dim sourceview As NotesView Dim sourcedoc As NotesDocument Dim dataview As NotesView Dim dc As NotesDocumentCollection Dim datadoc As NotesDocument Dim maxcols As Integer Dim WS As New Notesuiworkspace Dim ViewString As String Dim Scope As String Dim GetField As Variant Dim C As NotesViewColumn Dim FieldName As String Dim K As Integer Dim N As Integer Dim xlApp As Variant Dim xlsheet As Variant Dim rows As Integer Dim cols As Integer Dim nitem As NotesItem Dim entry As NotesViewEntry Dim vwNav As NotesViewNavigator Dim ShowView() As Variant Dim i As Integer Dim VList As Variant Dim ColVals As Variant '***** Vous pouvez modifier le code pour qu'il fasse appel à une autre base dedocument Set db = session.CurrentDatabase Vlist= db.views ' Récupère les vue de la base K=Ubound(Vlist) ' Récupère le nombre de vue Redim Preserve ShowView(K) N=-1 For i = 0 To K If Len(Vlist(i).Name) >0 Then FieldName=Trim(Vlist(i).Name) If Mid(Fieldname,1,1) <>"(" Then ' On n'affiche pas les vues caché N=N+1 ShowView(N) = FieldName End If End If Next i Redim Preserve ShowView(N) ' Trie les vues par ordre alphabétique For i=0 To N For K=i To N If ShowView(i) > ShowView(k) Then FieldName=ShowView(i) ShowView(i) = ShowView(k) ShowView(k)=FieldName End If Next k Next i viewstring= ws.Prompt(PROMPT_OKCANCELLIST,"Liste des vues","Choisissez unevue","",ShowView ) If Len(viewstring)=0 Then Exit Sub Set dataview = db.getview(ViewString) ' Ouvre la vue Set vwnav= dataview.createViewnav() rows = 1 cols = 1 maxcols=dataview.ColumnCount ' Récupère le nombre de colonne Set xlApp = CreateObject("Excel.Application")' Lance Excel xlApp.StatusBar = "Création du tableau. Veuillez patienter..." xlApp.Visible = True xlApp.Workbooks.Add xlApp.ReferenceStyle = 2 Set xlsheet = xlApp.Workbooks(1).Worksheets(1) ' On prend la premièrefeuille du classeur ' On met le titre de la vue xlsheet.Cells(rows,cols).Value ="Vue : " + ViewString + ", de la base : " +db.title +", extraction du : " + Format(Now,"mm/dd/yyyy HH:MM") xlApp.StatusBar = "Création des entêtes de colonnes. Veuillez patienter..." rows=2 ' On commence à la deuxième ligne For K=1 To maxcols Set c=dataview.columns(K-1) xlsheet.Cells(rows,cols).Value = c.title cols = cols + 1 Next K Set entry=vwnav.GetFirstDocument rows=3 ' On se place sur la troisième ligne Do While Not (entry Is Nothing) For cols=1 To maxcols colvals=entry.ColumnValues(cols-1) scope=Typename(colvals) Select Case scope Case "STRING" xlsheet.Cells(rows,cols).Value ="'" + colvals Case Else xlsheet.Cells(rows,cols).Value = colvals End Select Next cols xlApp.StatusBar = "Importation des données - Document " & rows-1 '& " sur" & dc.count & "." rows=rows+1 Set entry = vwnav.getnextdocument(entry) Loop xlApp.Rows("1:1").Select xlApp.Selection.Font.Bold = True xlApp.Selection.Font.Underline = True xlApp.Range(xlsheet.Cells(2,1), xlsheet.Cells(rows,maxcols)).Select xlApp.Selection.Font.Name = "Arial" xlApp.Selection.Font.Size = 9 xlApp.Selection.Columns.AutoFit With xlApp.Worksheets(1) .PageSetup.Orientation = 2 .PageSetup.centerheader = "Rapport" .Pagesetup.RightFooter = "Page &P" & Chr$(13) & "Date : &D" .Pagesetup.CenterFooter = "" End With xlApp.ReferenceStyle = 1 xlApp.Range("A1").Select xlApp.StatusBar = "L'importation des données de Lotus Notes est terminé." '***** Vous pouvez activer la ligne ci-dessous si vous voulez enregistrerle document en automatique 'xlapp.ActiveWorkbook.saveas "C:\Vue" + Trim(Format(Now,"yyy")) ' Sauve ledocument dataview.clear Set xlapp=Nothing ' Stop l'automation excel Set db=NothingEnd Sub[%sig%]

Re: Export vers Excel

MessagePublié: 25 Mai 2003 à 21:55
par WKTFE
Si ce n'est pas une réponse complète alors je ne m'y connais plus !Merci Stéphane et bonne semaine !

Re: Export vers Excel

MessagePublié: 02 Juin 2003 à 13:52
par Débutant2
Et en plus ça marche !!!Grand merci Stéphane !

Re: Export vers Excel

MessagePublié: 03 Juin 2003 à 11:16
par Philippe Zouzoulas
Salut,Est-il possible de changer facilement ce code afin d'avoir une sortie vers Access à la place de Excel.Dans ce cas, où puis-je trouver l'info ?Philippe.

Re: Export vers Excel

MessagePublié: 03 Juin 2003 à 11:20
par Raziel
Salut,Dans le cas d'acces, il te faudra passé par un lien odbc. Je pense qu'il doit y avoir des exemple sur Notes.net dans la sandbox.

Re: Export vers Excel

MessagePublié: 04 Juin 2003 à 10:32
par Philippe Zouzoulas
salut,merci pour l'indice. je suis allé voir mais finalement je vais me débrouiller avec Excel ;) ODBC c'est carrément anti-convivial et anti-pratique !phi.

Re: Export vers Excel

MessagePublié: 04 Juin 2003 à 13:37
par delp07
et on le met où tout ce code ??? et si je ve automatiser l'export c déjà prevu avec cette formule ou il faut creer un agent?mercidelp

Re: Export vers Excel

MessagePublié: 04 Juin 2003 à 13:42
par Raziel
SalutQuand tu parle d'automatisme, c'est forcément un agent programmé. Il te suffit de recopier le code dans ton agent et le tour est joué.

Re: Export vers Excel

MessagePublié: 04 Juin 2003 à 14:27
par delp07
je retrouve pas mon doc excel où j'ai exporté mes messages ... (je sais que j'ai pleins de trucs a apprendre encore) comment ça marche?

et importation depuis excel ?

MessagePublié: 04 Juin 2003 à 14:56
par Cuatan
bjr si qqn peux m'aider : moi c'est l'inverse je cherche a importer des info excel specifique ds une vue notes ! le pb est de passer par une feuille 123 car pose des pb avec les liens entre les fichiers excel . donc j'aimerai eviter ca..bref une solution pour recuperer une liste et 'limporter ds une vue direct par un .xls? en lotus cript ca me derange pas ! faudra que je l'automatise...mci bcp !

et importation depuis excel ?

MessagePublié: 04 Juin 2003 à 14:56
par Cuatan
bjr si qqn peux m'aider : moi c'est l'inverse je cherche a importer des info excel specifique ds une vue notes ! le pb est de passer par une feuille 123 car pose des pb avec les liens entre les fichiers excel . donc j'aimerai eviter ca..bref une solution pour recuperer une liste et 'limporter ds une vue direct par un .xls? en lotus cript ca me derange pas ! faudra que je l'automatise...mci bcp !

Re: Export vers Excel

MessagePublié: 04 Juin 2003 à 15:14
par Raziel
Qu'a tu mis pour ton SaveAsTon fichier doit normalement se trouver à cet endroit...