Philippe Sentenac
Développer des User Defined Functions pour Excel Services
Après une présentation des Excel Services, nous verrons comment étendre la librairie de fonctions déjà disponible avec Excel grâce aux User Defined Functions (UDF).
Par Philippe Sentenac publié le 16/03/2008 à 23:35
 
Il y a trois composants de base des Excel Services qui interagissent les uns avec les autres et qui forment l'ensemble de la conception de la structure des Excel Services :
  • Les Excel Calculation Services (ECS) sont le « moteur » des Excel Services qui chargent les classeurs, les calculent de la même manière que le ferait Microsoft Excel 2007, rafraichissent les éventuelles données externes et gèrent les sessions utilisateurs liés aux documents. Dans le cas où la charge sur le serveur deviendrait trop lourde, il est tout à fait possible de mettre en place un système d'équilibrage afin d'améliorer les performances.
  • Excel Web Access est une WebPart qui affiche les feuilles de données avec du DHTML et du JavaScript permettant ainsi de garder pratiquement le même rendu sur de nombreuses plateformes et navigateurs. Une fois que vous avec correctement configuré Excel Services, vous pouvez déposer cette WebPart sur n'importe quelle page pour visualiser vos feuilles Excel, la connecter à d'autres WebParts et même créer des tableaux de bords.
  • Les Excel Web Services (EWS) fournissent un ensemble d'interfaces de programmation (API) pour Excel Services. En utilisant ces web services vous pouvez développer vos propres applications qui utiliseront le moteur de calcul d'Excel Services. Cela permettra à vos applications de se décharger du traitement du calcul, couteux en termes de ressources. Les EWS sont publiés depuis le serveur où résident les Shared Services Providers (SSP) de SharePoint.
 
Architecture

Architecture

 
Il n'y a pas de soin particulier à apporter à un classeur destiné à être publié grâce aux Excel Services. Celui-ci peut contenir des formules de calcul, utiliser des connexions aux bases de données ou à Analysis Services, etc.
 
Exemple d'EWA

Exemple d'EWA

 
Une fois publié, le document s'ouvre automatiquement dans le navigateur. De plus, si vous en avez les droits, vous pourrez l'ouvrir dans Office Excel 2007 ou accéder à un cliché (SnapShot). Un « SnapShot » sauvegarde uniquement les données ainsi que le format du document, et cache les formules et les connections aux données. Cela peut s'avérer très utile lorsque vous souhaitez protéger votre logique métier ou sauvegarder des données pour en faire des archives.
Les Excel Services ne permettent pas uniquement de publier et d'afficher des classeurs, mais offrent la possibilité d'utiliser des paramètres, ce qui accroit l'interactivité et permet de généraliser ses formules de calcul.
 
Utilisation de paramètres

Utilisation de paramètres

 
In fine, les paramètres permettent de spécifier des cellules à l'intérieur des feuilles de calcul pour lesquelles l'utilisateur pourra saisir directement les valeurs. Toutes les modifications réalisées sur la page sont liées à une session et n'impactent pas les autres utilisateurs. En revanche, si un utilisateur ayant suffisamment de permissions édite et publie à nouveau le classeur Excel, le document accessible depuis le navigateur est mis à jour.
Enfin, les services de calcul permettent aux applications tierces de bénéficier de centaines de formules natives dans Excel ou publiées dans les Excel Services.
La première limitation des Excel Services à prendre en compte est qu'ils ne constituent en aucun cas un tableur en ligne. En effet, s'ils permettent une certaine interaction avec des classeurs Excel sur le Web, vous ne pourrez pas créer de nouveaux documents et Microsoft Office Excel 2007 reste nécessaire pour la création et l'édition des feuilles de calcul.
Bien que l'objectif des Excel Services soit, à terme, d'intégrer toutes les fonctionnalités d'Excel, certaines ne sont pas encore opérationnelles dans la première version :
  • VBA : Visual Basic for Applications ne sera vraisemblablement jamais supporté par les Excel Services, l'alternative proposée étant l'utilisation des UDF.
  • Ancien format de fichier : Seuls les fichiers .xslx et .xslb (format Excel 2007) fonctionnent avec les Excel Services. Il existe néanmoins des convertisseurs qui vous permettront d'exploiter vos anciens documents.
  • Classeur externes : Excel a la possibilité de référencer des cellules provenant d'autres classeurs. Cette fonctionnalité pose des problèmes lors de publication qui peuvent être facilement contournées grâce à un développement en interne.
  • Données en temps réel : Excel supporte une fonctionnalité nommée RTD (Real Time Data) qui se connecte à la source des données et met à jour la feuille de calcul si nécessaire. Cette fonctionnalité n'est pas présente par défaut dans Excel Services même s'il est possible avec certaines limitations de mettre en place ce principe de fonctionnement.
  • Pas de support client : Excel ne gère pas l'utilisation d'UDF et affichera #NAME dans la cellule où vous faites appel à votre formule. Comme nous le verrons plus loin, il est néanmoins possible de modifier les UDF pour leur ajouter le support COM.
  • Autres fonctionnalités : les Clip Art et Word Art, les Contrôles ActiveX, et l'IRM ne sont pas intégrés à cette version.

 Commentaire - Développer des User Defined Functions pour Excel Services  

 Dernières Publications      

Exploiter les données CSV via Linq en toute simplicité
  A partir du requêteur dynamique fourni en exemple avec Visual Studio 2008, nous allons essayer de remplir les propriétés d'un ensemble d'objets à partir des données d'un fichier CSV. Nous enrichirons aussi le parseur de nos propres fonctions.
par Frédéric Mélantois posté le 17/05/2008 à 11:41, lu 142 fois, #0
Polymorphisme et contrats de données WCF
  WCF aborde les types polymorphes du point de vue de la sérialisation. En effet, la connaissance du type réel potentiel est rendue nécessaire dès la description du contrat de données. Une fois n'est pas coutume, j'ai réalisé l'exemple en VB.NET.
par Frédéric Colin posté le 14/05/2008 à 08:40, lu 297 fois, #2
A la découverte de BizTalk Server 2006 3/3
  Développer un assembleur pour BizTalk Server 2006 R2
par Kader Yildirim posté le 06/05/2008 à 13:20, lu 147 fois, #0
Chapitre III : Sync Services for ADO.NET et WCF
   Suite des deux premiers chapitres sur la synchronisation avec Sync Services for ADO.NET, voici un nouvel article impliquant WCF dans une synchronisation déconnectée.
Requêtes dynamiques sur les IEnumerable
  A partir d'un exemple fourni avec Visual Studio 2008, initialement prévu pour tout objet Queryable, nous allons présenter comment en ajoutant très peu de code rendre disponible aux IEnumerable un requêteur dynamique.
par Frédéric Mélantois posté le 24/04/2008 à 15:03, lu 842 fois, #0
Développer une visionneuse d'images avec WPF et WCF
  Au travers de cet article, nous allons découvrir comment mettre en place une visionneuse d'images, grâce aux technologies WPF et WCF.
par Thomas Lebrun posté le 22/04/2008 à 22:46, lu 1009 fois, #2
LINQRoleProvider
  L'objectif de cet article est d'implémenter un fournisseur de rôles ASP.NET personnalisé à l'aide de LINQ To Sql tout en faisant un tour d'horizons de la syntaxe des requêtes LINQ.
par Antoine Griffard posté le 13/04/2008 à 22:18, lu 491 fois, #4
WCF : Transfert de messages streamés et sécurisation personnalisée
  Je poursuis ma série d'articles sur WCF en vous présentant cette fois-ci le mode de communication Streamé. Histoire d'aller un petit peu plus loin, j'ai protégé le service de manière personnalisée et utilisé un binding très courant : BasicHttpBinding
par Frédéric Colin posté le 07/04/2008 à 08:12, lu 885 fois, #0

 Dernières Actualités      

Injection de code et API de profiling .NET
  Si vous êtes intéressés par la sécurité du Framework, par le reverse engineering et la manipulation/injection de code .NET et les packers, alors jetez un coup d’œil...
NDepend pour l'analyse statique de code .NET
  Pour ceux qui ne connaissent pas NDepend , il s’agit d’un outil d’analyse statique de code .NET qui permet de remonter des informations à toute une équipe de développement. NDepend aide à travailler sur...
Tags: Outils
Microsoft met à disposition son IoC Container Unity 1.0 en version finale
  Microsoft met à disposition la version 1.0 de son IoC container Unity, sur CodePlex sous la forme d'un Application Block des Enterprise Library. Si vous voulez en savoir plus sur le sujet en .NET je vous...
Tags: Application Block
Microsoft MVP (Most Valuable Professional) sur Tech Head Brothers
  Je voudrais féliciter les nouveaux Microsoft MVP (Most Valuable Professional) du mois d'Avril 2008 qui publient sur Tech Head Brothers! Sans les auteurs le site ne serait rien. Sébastien Pertus - MVP SQL...
Les Webcasts des Microsoft TechDays 2008 sont en ligne
  Si vous avez participé ou non au Microsoft TechDays 2008 vous avez certainement manqué certaines présentation qui vous intéressaient. Voilà enfin votre chance de pouvoir suivre ces présentations en ligne...
Rapide résumé de la conférence MIX08
  La conférence MIX08 s'est achevée la semaine dernière avec peu d'annonces de nouvelles technologies (DeepZoom) mais surtout des releases de produits (et c'est pas un mal...). Nous avons donc eu droit aux...