IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

Bibliothèques et frameworks PHP Discussion :

[PHPExcel] Verrouiller colonne précise


Sujet :

Bibliothèques et frameworks PHP

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Homme Profil pro
    Inscrit en
    Avril 2013
    Messages
    22
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 34
    Localisation : France

    Informations forums :
    Inscription : Avril 2013
    Messages : 22
    Par défaut [PHPExcel] Verrouiller colonne précise
    Bonjour a tous,

    Voila, je dois dans un de mes scripts faire en sorte que deux colonnes UNIQUEMENT soient verrouiller, les colonnes A et B ( si possible juste verouiller au niveau de la saisie et pas du redimensionnement mais ça je ne suis pas sur que c'est possible )

    Et je veux que toutes les autres colonnes même vide soit deverouiller bien sur

    Apparement j'ai cru comprendre que pour activer les fonctions de protection il faut utiliser
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    $sheet->getProtection()->setSheet(true);
    Mais ça a pour effet de verouiller toute la feuille, ensuite on peut deverouiller des cellules au cas par cas avec
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    $sheet->getStyle('C1')->getProtection()->setLocked(PHPExcel_Style_Protection::PROTECTION_UNPROTECTED);
    Mais ça n'est pas vraiment ce que je veux faire.

    J'ai essayé la fonction

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    PHPExcel_Worksheet::protectCellsByColumnAndRow	(	$ 	pColumn1 = 0,
    $ 	pRow1 = 1,
    $ 	pColumn2 = 0,
    $ 	pRow2 = 1,
    $ 	pPassword = '',
    $ 	pAlreadyHashed = false 
    )		
    Set protection on a cell range by using numeric cell coordinates
     
    Parameters:
    int	$pColumn1	Numeric column coordinate of the first cell
    int	$pRow1	Numeric row coordinate of the first cell
    int	$pColumn2	Numeric column coordinate of the last cell
    int	$pRow2	Numeric row coordinate of the last cell
    string	$pPassword	Password to unlock the protection
    boolean	$pAlreadyHashed	If the password has already been hashed, set this to true
    Mais ça ne fais rien ... Ou alors ça agit mais vu que tout est déjà verrouiller a cause de $sheet->getProtection()->setSheet(true); je ne vois pas l'intérêt.

    Merci d'avance de votre aide !!

  2. #2
    Membre confirmé
    Homme Profil pro
    Étudiant
    Inscrit en
    Novembre 2012
    Messages
    90
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Novembre 2012
    Messages : 90
    Par défaut
    Bonjour,

    Je suis moi même en train de découvrir cette librairie.

    Pourquoi tu ne dévérouilles pas toute ta feuille à l'aide de :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    $sheet->getProtection()->setSheet(false);
    Puis vérouiller uniquement tes colonnes A et B (cellule par cellule) :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    for ($row=1;$row<=$highestRow;$row++)
    {
    $sheet->getStyle('A'.$row)->getProtection()->setLocked(PHPExcel_Style_Protection::PROTECTION_PROTECTED);
    $sheet->getStyle('B'.$row)->getProtection()->setLocked(PHPExcel_Style_Protection::PROTECTION_PROTECTED);
    }

  3. #3
    Membre averti
    Homme Profil pro
    Inscrit en
    Avril 2013
    Messages
    22
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 34
    Localisation : France

    Informations forums :
    Inscription : Avril 2013
    Messages : 22
    Par défaut
    C'est la ou réside la beauté de cette bibliothèque que je suis forcer d'apprendre au boulot egalement ^^ comme j'ai dit j'ai essayé ( enfin j'avais pas mit sur false vu que c'est par defaut je viens d'essayer et ça change rien )

    Le seul moyen de verrouiller que j'ai trouvé, c'est de verrouiller le sheet entier, et déverrouiller au cas pas cas. Mais ça n'est pas ce que je veux

    Si tu démarres toi aussi avec cette biblio, un petit conseil, laisse tomber le Excel2007 et fait au format Excel5. Y'a des fonctions bien pratique comme GetHighestColumn qui ne fonctionne pas sur Excel2007. En plus quand j'ouvre avec openoffice a la main un fichier xlsx et que je réexecute un script dessus il se retrouve corrompu.

Discussions similaires

  1. Verrouiller colonnes sous WSS 3.0
    Par falconix dans le forum SharePoint
    Réponses: 4
    Dernier message: 28/04/2009, 16h31
  2. Réponses: 4
    Dernier message: 18/10/2007, 15h09
  3. Trouver les tables possédant une colonne précise
    Par keumlebarbare dans le forum Oracle
    Réponses: 2
    Dernier message: 17/10/2006, 13h07
  4. Réponses: 11
    Dernier message: 16/05/2006, 14h31
  5. Exporter des colonnes précises dans excel
    Par uloaccess dans le forum Access
    Réponses: 8
    Dernier message: 30/12/2005, 15h16

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo