Nouvelles fonctions pour travailler avec des chaînes. Nouvelles fonctions pour travailler avec des chaînes Travailler avec des chaînes en 1c

Une chaîne est l'un des types de données primitifs dans les systèmes 1C:Enterprise 8. Variables de type doubler contenir du texte.

Tapez les valeurs des variables doubler sont entourés de guillemets doubles. Plusieurs variables de ce type peuvent être ajoutées.

Per1 = "Mot 1" ;
Per2 = "Mot 2" ;
Per3 = Per1 + " " + Per2 ;

Finalement Par3 signifiera " Mot 1 Mot 2″.

De plus, les systèmes 1C:Enterprise 8 fournissent des fonctions permettant de travailler avec des chaînes. Regardons les principaux :

EntréeChaîne(<Строка>, <Подсказка>, <Длина>, <Многострочность>) — la fonction est conçue pour afficher une boîte de dialogue dans laquelle l'utilisateur peut spécifier la valeur d'une variable de type Doubler. Paramètre <Строка> est obligatoire et contient le nom de la variable dans laquelle la chaîne saisie sera écrite. Paramètre <Подсказка> facultatif - c'est le titre de la boîte de dialogue. Paramètre <Длина> facultatif, affiche la longueur maximale de la chaîne d'entrée. La valeur par défaut est zéro, ce qui signifie une longueur illimitée. Paramètre <Многострочность> facultatif. Définit le mode de saisie de texte multiligne : True : saisie de texte multiligne avec séparateurs de ligne ; False : entrez une chaîne simple.

Vous pouvez saisir une chaîne si vous connaissez le code du caractère en Unicode :

Symbole(<КодСимвола>) — le code est saisi sous forme de nombre.

Lettre= Symbole(1103) ; // JE

Il existe également une fonction inverse qui permet de connaître le code d'un symbole.

SymboleCode(<Строка>, <НомерСимвола>) — renvoie le numéro Unicode du caractère spécifié sous forme de nombre.

Fonctions de conversion de casse de texte :

VReg(<Строка>) — Convertit tous les caractères d'une chaîne en majuscules.

NReg(<Строка>) — Convertit tous les caractères d'une chaîne en minuscules.

TReg(<Строка>) — convertit tous les caractères de la chaîne en casse du titre. Autrement dit, les premières lettres de tous les mots sont converties en majuscules et les lettres restantes sont converties en minuscules.

Fonctions de recherche et de remplacement de caractères dans une chaîne :

Trouver(<Строка>, <ПодстрокаПоиска>) — trouve le numéro de caractère de l'occurrence de la sous-chaîne recherchée. Par exemple:

Rechercher ("Chaîne" , "oka" ) ; // 4

StrFind(<Строка>, <ПодстрокаПоиска>, <НаправлениеПоиска>, <НачальнаяПозиция>, <НомерВхождения>) — trouve le numéro de caractère de l'occurrence de la sous-chaîne recherchée, le numéro d'occurrence est indiqué dans le paramètre correspondant. Dans ce cas, la recherche commence par le caractère dont le numéro est précisé dans le paramètre Position initiale. La recherche est possible depuis le début ou la fin de la chaîne. Par exemple:

Nombre4 Occurrences = Str Rechercher ( "Défense", "à propos", sens de recherche. Depuis le début, 1, 4); // 7

StrRemplacer(<Строка>, <ПодстрокаПоиска>, <ПодстрокаЗамены>) – trouve toutes les occurrences de la sous-chaîne de recherche dans la chaîne source et la remplace par la sous-chaîne de remplacement.

StrReplace ("Chaîne" , "oka" , "" ) ; // Page

Ligne vide (<Строка>) – vérifie la chaîne pour les caractères significatifs. S'il n'y a aucun caractère significatif, ou aucun caractère du tout, alors la valeur est renvoyée Vrai. Sinon - Mensonge.

StrNumberOccurrences(<Строка>, <ПодстрокаПоиска>) – Calcule le nombre d'occurrences de la sous-chaîne de recherche dans la chaîne source.

StrNumberOccurrences ( "Étudiez, étudiez et étudiez encore", "étude" , "" ) ; // 3

StrTemplate(<Строка>, <ЗначениеПодстановки1>…<ЗначениеПодстановкиN> — remplace les paramètres dans une chaîne par un nombre. La ligne doit contenir des marqueurs de substitution de la forme : « %1..%N ». La numérotation des marqueurs commence à 1. Si la valeur du paramètre Indéfini, une chaîne vide est remplacée.

ModèleStr ( "Paramètre 1 = %1, Paramètre 2 = %2", "1" , "2" ) ; // Paramètre 1= 1, Paramètre 2 = 2

Fonctions de conversion de chaîne :

Un lion(<Строка>, <ЧислоСимволов>) – renvoie les premiers caractères d'une chaîne.

Droite(<Строка>, <ЧислоСимволов>) – renvoie les derniers caractères d'une chaîne.

Mercredi(<Строка>, <НачальныйНомер>, <ЧислоСимволов>) – renvoie une chaîne de longueur<ЧислоСимволов>, à partir du symbole<НачальныйНомер>.

Abréviation(<Строка>) supprime les caractères non significatifs à gauche du premier caractère significatif de la chaîne.

Abréviation(<Строка>) — coupe les caractères insignifiants à droite du dernier caractère significatif de la ligne.

AbréviationLP(<Строка>) – coupe les caractères insignifiants à gauche du premier caractère significatif de la ligne et à droite du dernier caractère significatif de la ligne.

StrGetString(<Строка>, <НомерСтроки>) – Obtient une chaîne multiligne par numéro.

Autres caractéristiques:

LongueurStre(<Строка>) – renvoie le nombre de caractères dans la chaîne.

StrNumberRow(<Строка>) – renvoie le nombre de lignes dans une chaîne multiligne. Une ligne est considérée comme nouvelle si elle est séparée de la précédente par un caractère de nouvelle ligne.

StrCompare(<Строка1>, <Строка2> ) – compare deux chaînes sans tenir compte de la casse. Une fonction fonctionne de la même manière qu'un objet Comparaison des valeurs. Retour:

  • 1 - si la première ligne est supérieure à la seconde
  • -1 - si la deuxième ligne est supérieure à la première
  • 0 - si les chaînes sont égales

StrCompare("Première ligne" , "Deuxième ligne" ) ; // 1

Les caractères spéciaux dans 1C 8.3 sont un ensemble de caractères spéciaux pour les types de données chaîne.

Examinons chacun d'eux plus en détail.

Caractères spéciaux en 1C : VK, VTab, NPP, PS, PF, Tab

Les caractères spéciaux sont appelés à l'aide de la propriété globale « Caractères », par exemple :

Texte = « Texte avant la tabulation » + Symbols.Tab + « texte après la tabulation » ;

Obtenez 267 leçons vidéo sur 1C gratuitement :

  • VC (CR) - retour chariot. Autrefois, sur les imprimantes matricielles ou en marguerite, ce code de caractère était utilisé comme une commande qui ramenait la tête d'impression au début de la ligne.
  • NSP (NBSp) - espace insécable (souvent vu dans les chaînes numériques, par exemple : 1 000).
  • PS (LF) - Saut de ligne (LF - saut de ligne) - faites défiler le tambour d'une ligne vers le bas, la tête d'impression est au même endroit.
  • PF (FF) - traduction de format. La feuille est éjectée de l'imprimante et l'impression commence sur une nouvelle feuille.
  • Tab est le caractère de tabulation. La tabulation horizontale est une façon de se positionner pour imprimer sur la colonne la plus proche qui est un multiple d'un nombre (par exemple, 8, 16, 24...).
  • VTab - tabulation verticale. Similaire à l'horizontal, mais positionné sur une ligne. Provoque un certain défilement du tambour de l'imprimante (la tête d'impression reste dans la même position (colonne) !)

PS + VK est une combinaison qui effectue deux opérations : elle fait défiler la bobine sur une ligne et ramène le chariot d'impression au début de la ligne, ce qui correspond à ce que l'utilisateur s'attend à obtenir en appuyant sur Entrée.

Si vous commencez à apprendre la programmation 1C, nous vous recommandons notre cours gratuit (n'oubliez pas

Implémenté dans la version 8.3.6.1977.

Nous avons élargi l'ensemble des fonctions conçues pour fonctionner avec des chaînes. Nous avons fait cela afin de vous offrir des outils plus avancés pour analyser les données de chaîne. Les nouvelles fonctions seront pratiques et utiles dans les tâches technologiques d'analyse de texte. Dans les tâches liées à l'analyse de texte contenant des données sous forme formatée. Il peut s'agir d'une analyse de certains fichiers reçus de l'équipement ou, par exemple, d'une analyse d'un journal technologique.

Vous pouvez auparavant effectuer toutes les actions qui remplissent de nouvelles fonctions. Utiliser des algorithmes plus ou moins complexes écrits dans un langage intégré. Par conséquent, les nouvelles fonctions ne vous offrent pas de capacités fondamentalement nouvelles. Cependant, ils permettent de réduire la quantité de code et de rendre le code plus simple et plus compréhensible. De plus, ils permettent d'accélérer l'exécution des actions. Parce que les fonctions implémentées dans la plateforme fonctionnent, bien entendu, plus rapidement qu'un algorithme similaire écrit dans un langage intégré.

Fonction de formatage StrTemplate()

Cette fonction remplace les paramètres dans une chaîne. La nécessité d'une telle conversion apparaît souvent, par exemple, lors de l'affichage de messages d'avertissement. La syntaxe de cette fonction est la suivante :

StrTemplate(<Шаблон>, <Значение1-Значение10>)

<Шаблон>- c'est la chaîne dans laquelle vous devez remplacer les représentations des paramètres.

<Значение1> , ... <Значение10>- ce sont des paramètres (dix au maximum) dont les représentations doivent être substituées dans la chaîne.

Pour indiquer un endroit spécifique du modèle où vous souhaitez effectuer la substitution, vous devez utiliser des marqueurs comme %1, ... %10. Le nombre de marqueurs impliqués dans le modèle et le nombre de paramètres contenant des valeurs doivent correspondre.

Par exemple, le résultat de l'exécution d'un tel opérateur :

il y aura une ligne :

Erreur de données sur la ligne 2 (type de date requis)

Fonction pour travailler avec des chaînes StrCompare()

Cette fonction compare deux chaînes sans tenir compte de la casse. Par exemple, comme ceci :

Vous pouvez effectuer la même action plus tôt à l'aide de l'objet Comparaison de valeurs :

Cependant, l’utilisation de la nouvelle fonctionnalité semble plus simple. Et en plus de cela, la fonction, contrairement à l'objet Comparaison de valeurs, fonctionne à la fois dans le client léger et dans le client Web.

Fonctions pour travailler avec des chaînes StrStartsWith(), StrEndsAt()

Ces fonctions déterminent si une chaîne commence par une sous-chaîne spécifiée ou si une chaîne se termine par une sous-chaîne spécifiée. L'algorithme de ces fonctions n'est pas difficile à implémenter dans un langage embarqué, mais leur présence permet d'écrire un code plus propre et plus compréhensible. Et ils travaillent plus vite.

Par exemple, ils sont pratiques à utiliser dans l'instruction If :

Fonctions pour travailler avec des chaînes StrDivide(), StrConnect()

Ces fonctions divisent une chaîne en parties à l'aide d'un délimiteur spécifié. Ou vice versa, ils combinent plusieurs lignes en une seule, en insérant le séparateur sélectionné entre elles. Ils sont pratiques pour créer ou analyser des journaux et des revues technologiques. Par exemple, vous pouvez facilement analyser une entrée de journal technologique en parties adaptées à une analyse plus approfondie :

Fonction pour travailler avec des chaînes StrFind()

Au lieu de l'ancienne fonction Find(), nous avons implémenté une nouvelle fonction qui possède des fonctionnalités supplémentaires :

  • Rechercher dans différentes directions (du début, de la fin) ;
  • Rechercher à partir d'une position spécifiée ;
  • Rechercher une occurrence avec un numéro spécifié (deuxième, troisième, etc.).

En fait, cela duplique les capacités de l’ancienne fonction. Ceci est fait afin de maintenir la compatibilité avec les modules compilés dans les anciennes versions. Il est recommandé de ne plus utiliser l'ancienne fonction Find().

Vous trouverez ci-dessous un exemple utilisant les nouvelles fonctionnalités de recherche. La recherche inversée est utile lorsque vous avez besoin de la dernière partie d'une chaîne formalisée, telle que le nom complet du fichier dans une URL. Et la recherche à partir d'une position spécifiée est utile dans les cas où vous devez rechercher dans un fragment connu, et non dans toute la ligne.

Les informations en 1C peuvent être présentées : un annuaire, un document, un registre...

Cependant, en fin de compte, tous ces objets sont constitués de champs, et les champs sont de types simples : nombre, chaîne, date. Et il y a toujours plus d’informations sous forme de chaînes. Par conséquent, vous devez travailler plus souvent avec des cordes.

Nous allons maintenant voir comment travailler avec des chaînes du langage 1C. Dans le même temps, nous essaierons diverses options d’analyse automatique de texte.

Types de chaînes

Les lignes peuvent être de longueur limitée ou illimitée. Si la valeur de chaîne est extraite d'un attribut, alors cette restriction est indiquée dans le type d'attribut.

Si la ligne a été saisie par l'utilisateur sur le formulaire, alors l'élément de formulaire peut avoir les cases à cocher « Mode multi-ligne » et « Édition avancée ». Le premier signifie que la ligne peut contenir des caractères « saut de ligne 1C (Entrée) ». La seconde est que la ligne peut contenir d'autres symboles de service 1C, par exemple TAB.

Si une ligne est extraite d'un fichier, par exemple en utilisant ReadText(), alors l'encodage devient également important - lors de la lecture d'un fichier, vous devez spécifier l'encodage (UTF-8, KOI8, etc.).

Symboles de service 1C

Pour travailler avec des caractères spéciaux, l'énumération des symboles 1C est utilisée.

Par exemple, une valeur de chaîne composée de deux mots :
TextString = "Première ligne" + Symbols.PS + "Deuxième ligne" ;

Par exemple, rechercher un saut de ligne 1C dans le texte :
Position = Rechercher (TextString, Characters.PS);

Vous pouvez travailler avec les caractères spéciaux suivants :

  • CR et LF
    Ils signifient un saut de ligne 1C. Souvent trouvé dans les fichiers texte.
    Le code de caractère en ASCII est 0x0D et 0x0A, en Unicode - U+000D et U+000A.

    Dans le langage 1C, ils ressemblent à Symbols.CR et Symbols.LF, ou en russe Symbols.VK et Symbols.PS. Pour transférer une ligne 1C lors de sa création en code 1C, il suffit d'utiliser PS.

Autres symboles 1C

Les chaînes en 1C sont « physiquement » utilisées au format Unicode (Unicode, http://ru.wikipedia.org/wiki/%DE%ED%E8%EA%EE%E4).

Si vous n’avez jamais rencontré de « codage » de caractères auparavant, notons brièvement :

  • Lorsqu'il travaille avec des chaînes, l'ordinateur utilise des numéros de lettres et non les lettres elles-mêmes.
  • Puisqu'il existe de nombreux alphabets « humains » (anglais, russe, grec, chinois, etc., et qu'il existe également des symboles 1C de service et « non imprimables »), il existe plusieurs options pour les alphabets informatiques, dont l'un est Unicode, qui comprend les symboles 1C dans toutes les langues
  • L'alphabet Unicode ressemble à ceci :
    o Symboles de service 1C courants « non imprimables »
    o Signes préjudiciables et mathématiques
    o Chiffres
    oAlphabet anglais
    o Ajouter. Caractères 1C de l'alphabet anglais, utilisés dans les langues européennes (par exemple l'allemand)
    o alphabet grec
    oAlphabet russe
    o...

Si nécessaire, dans les lignes 1C, il est possible d'utiliser tous les caractères 1C disponibles en Unicode.

Tout d'abord, vous pouvez les saisir à partir du clavier si une disposition de clavier est installée sous Windows (la configuration par défaut en Russie est généralement l'anglais et le russe).

Deuxièmement, vous pouvez composer en utilisant la technique suivante :

Troisièmement, vous pouvez travailler à partir du code du programme. La fonction Character(Number) renvoie le caractère avec le numéro spécifié et la fonction CharacterCode(String) renvoie le numéro de caractère de la première lettre de la chaîne. Si vous avez besoin d'une autre lettre dans la ligne, alors CharacterCode(String, LetterNumber).

Par exemple, ajoutez le caractère Ž à la ligne suivante :
TextString = "Bonne bière en ville" + Caractère(381) + "drobinek";
//Résultat : "Bonne bière à Ždrobinek"

Les lignes de 1C 8.3 dans le langage intégré 1C représentent des valeurs d'un type primitif Doubler. Les valeurs de ce type contiennent une chaîne Unicode de longueur arbitraire. Les variables de type chaîne sont un ensemble de caractères entourés de guillemets.

Exemple 1. Créons une variable chaîne avec du texte.

StringVariable = "Bonjour tout le monde !";

Fonctions pour travailler avec des chaînes en 1s 8.3

Cette section fournira les principales fonctions qui vous permettront de modifier des lignes dans 1c, ou d'analyser les informations qu'elles contiennent.

LongueurStre

LongueurStre(<Строка>) . Renvoie le nombre de caractères contenus dans la chaîne passée en paramètre.

Exemple 2. Comptons le nombre de caractères dans la ligne « Hello World ! »

String = "Bonjour tout le monde !"; Nombre de caractères = StrLength(String); Rapport (NombreCaractères);

Le résultat de l'exécution de ce code sera l'affichage du nombre de caractères dans la ligne : 11.

Abréviation

Abréviation(<Строка>) . Supprime les caractères non significatifs à gauche du premier caractère significatif de la chaîne.
Personnages secondaires:

  • espace;
  • Espace non-cassant;
  • tabulation;
  • retour chariot ;
  • traduction de ligne ;
  • traduction du formulaire (page).

Exemple 3. Supprimez tous les espaces du côté gauche de la ligne « monde ! » et ajoutez-y la ligne « Bonjour ».

String = Abréviation("monde!"); Chaîne = "Bonjour"+Chaîne ; Rapport (Chaîne);

Le résultat de l'exécution de ce code sera l'affichage de la ligne « Hello world ! » sur l'écran.

Abrégé

Abréviation(<Строка>) . Supprime les caractères non significatifs à droite du premier caractère significatif de la chaîne.

Exemple 4. Formulaire à partir des lignes « Bonjour » et « paix ! la phrase « Bonjour tout le monde ! »

Ligne = Abréviation("Bonjour ")+" "+ Abréviation("monde!"); Rapport (Chaîne);

AbréviationLP

AbréviationLP(<Строка>) . Supprime les caractères non significatifs à droite du premier caractère significatif de la chaîne, ainsi que les caractères non significatifs à gauche du premier caractère significatif de la chaîne. Cette fonction est utilisée plus souvent que les deux précédentes, car elle est plus universelle.

Exemple 5. Supprimez les caractères insignifiants à gauche et à droite du nom de la contrepartie.

Contrepartie = Répertoires.Contreparties.Rechercher par détails("TIN", "0777121211"); AccountObject = Compte.GetObject(); CounterpartyObject.Name = AbbrLP(CounterpartyObject.Name); AccountObject.Write();

un lion

Un lion(<Строка>, <ЧислоСимволов>) . Récupère les premiers caractères de la chaîne, le nombre de caractères est spécifié dans le paramètre Nombre de caractères.

Exemple 6. Laisser entrer la structure Employé contenir les noms, prénom et patronyme du salarié. Obtenez une chaîne avec le nom de famille et les initiales.

NomInitial = Lev(Employé.Nom, 1); Patronymique Initial = Lion(Employé. Patronymique, 1) ; Nom complet = Employé.Nom + " " + Initiale Prénom + "." + Initiale du milieu + "." ;

Droite

Droite(<Строка>, <ЧислоСимволов>) . Récupère les derniers caractères d'une chaîne, le nombre de caractères spécifié dans le paramètre Nombre de caractères. Si le nombre de caractères spécifié dépasse la longueur de la chaîne, la chaîne entière est renvoyée.

Exemple 7. Laissez une date au format « aaaammjj » être écrite à la fin d'une variable de chaîne, récupérez une chaîne avec la date et convertissez-la en type date.

String = « Date actuelle : 20170910 » ; StringDate = Droits (Chaîne, 8); Date = Date(ChaîneDate);

Mercredi

Mercredi(<Строка>, <НачальныйНомер>, <ЧислоСимволов>) . Obtient une sous-chaîne de la chaîne passée en paramètre Doubler, à partir du caractère dont le numéro est précisé en paramètre Numéro initial et la longueur passée en paramètre Nombre de caractères. La numérotation des caractères dans une ligne commence à 1. Si dans le paramètre Numéro initial une valeur inférieure ou égale à zéro est spécifiée, alors le paramètre prend la valeur 1. Si le paramètre Nombre de caractères n'est pas spécifié, alors les caractères jusqu'à la fin de la ligne sont sélectionnés.

Exemple 8. Laissez la variable chaîne à partir de la neuvième position contenir le code de région, vous devriez l'obtenir et l'écrire sur une ligne séparée.

String = « Région : 99 Moscou » ; Région = Moy (Chaîne, 9, 2) ;

Recherche de page

StrFind(<Строка>, <ПодстрокаПоиска>, <НаправлениеПоиска>, <НачальнаяПозиция>, <НомерВхождения>) . Recherche une sous-chaîne spécifiée dans une chaîne, en renvoyant le numéro de position du premier caractère de la sous-chaîne trouvée. Regardons les paramètres de cette fonction :

  • Doubler. Chaîne source ;
  • Rechercher une sous-chaîne. Rechercher une sous-chaîne ;
  • Sens de recherche. Spécifie la direction dans laquelle rechercher une sous-chaîne dans une chaîne. Peut prendre des valeurs :
    • Direction de recherche. Depuis le début;
    • Recherche.Fin Direction;
  • Position initiale. Spécifie la position dans la chaîne à laquelle commence la recherche ;
  • NombreOccurrences. Spécifie le numéro d'occurrence de la sous-chaîne recherchée dans la chaîne source.

Exemple 9. Dans la ligne « Bonjour tout le monde ! Déterminez la position de la dernière occurrence du caractère « et ».

PositionNumber = StrFind("Bonjour tout le monde !", "et", SearchDirection.End); Rapport (PositionNumber);

Le résultat de l'exécution de ce code sera d'afficher le numéro de la dernière occurrence du symbole « et » : 9.

VReg

VReg(<Строка>) . Convertit tous les caractères de la chaîne spécifiée en 1s8 en majuscules.

Exemple 10 : Convertissez la chaîne "hello world!" en majuscules.

StringVreg = VReg("Bonjour tout le monde !"); Rapport (StringVreg);

Le résultat de l'exécution de ce code sera l'affichage de la ligne « HELLO WORLD !

NReg

NReg(<Строка>) . Convertit tous les caractères de la chaîne spécifiée en 1s8 en minuscules.

Exemple 11 : Convertissez la chaîne "HELLO WORLD!" en minuscules.

StringNreg = NReg("BONJOUR LE MONDE !"); Rapport (StringVreg);

Le résultat de l'exécution de ce code sera l'affichage de la ligne « hello world ! »

Treg

TReg(<Строка>) . Convertit une chaîne comme suit : le premier caractère de chaque mot est converti en majuscule, les caractères restants du mot sont convertis en minuscules.

Exemple 12 : Mettez en majuscule les premières lettres des mots de la ligne « hello world ! »

StringTreg = TReg("Bonjour tout le monde !"); Rapport (StringTreg);

Le résultat de l'exécution de ce code sera l'affichage de la ligne « Hello World ! »

Symbole

Symbole(<КодСимвола>) . Obtient un caractère par son code Unicode.

Exemple 13. Ajoutez gauche et droite à la ligne « Hello World ! » symbole ★

StringWithStars = Symbole("9733")+"Bonjour tout le monde !"+Symbol("9733"); Rapport (ChaîneAvecÉtoiles);

Le résultat de l'exécution de ce code sera l'affichage de la ligne « ★Hello World !★ »

Symbole Code

SymboleCode(<Строка>, <НомерСимвола>) . Obtient le code de caractère Unicode de la chaîne spécifiée dans le premier paramètre, située à la position spécifiée dans le deuxième paramètre.

Exemple 14. Découvrez le code du dernier caractère de la ligne « Hello World ! »

String = "Bonjour tout le monde !"; CharacterCode = CharacterCode (String, StrLength (String)); Notifier(CharacterCode);

Le résultat de l'exécution de ce code sera l'affichage du code symbole « ! » - 33.

Ligne vide

Ligne vide (<Строка>) . Vérifie si la chaîne ne contient que des caractères insignifiants, c'est-à-dire si elle est vide.

Exemple 15. Vérifiez si une chaîne composée de trois espaces est vide.

Vide = Chaîne Vide(" "); Rapport (vide);

Le résultat de l'exécution de ce code sera l'affichage du mot « Oui » (une expression chaîne d'une valeur logique Vrai).

PageRemplacer

StrRemplacer(<Строка>, <ПодстрокаПоиска>, <ПодстрокаЗамены>) . Recherche toutes les occurrences de la sous-chaîne de recherche dans la chaîne source et la remplace par la sous-chaîne de remplacement.

Exemple 16. Dans la ligne « Hello World ! » remplacer le mot « Paix » par le mot « Amis ».

String = StrReplace("Bonjour tout le monde !", "Monde", "Amis"); Rapport (Chaîne);

Le résultat de l'exécution de ce code sera l'affichage de la ligne « Hello Friends ! »

StrNombreLignes

StrNumberRow(<Строка>) . Permet de compter le nombre de lignes dans une chaîne multiligne. Pour passer à une nouvelle ligne en 1s 8, utilisez le symbole PS(caractère de nouvelle ligne).

Exemple 17. Déterminez le nombre de lignes dans le texte :
"Première ligne
Deuxième ligne
Troisième ligne"

Number = StrNumberString("Première ligne"+Characters.PS +"Deuxième ligne"+Symbols.PS +"Troisième ligne"); Signaler le numéro);

Le résultat de l'exécution de ce code sera l'affichage du nombre de lignes dans le texte : 3

StrGetString

StrGetString(<Строка>, <НомерСтроки>) . Obtient une ligne dans une chaîne multiligne par son numéro. La numérotation des lignes commence à 1.

Exemple 18. Récupérez la dernière ligne du texte :
"Première ligne
Deuxième ligne
Troisième ligne"

Texte = "Première ligne" + Symboles PS + "Deuxième ligne" + Symboles PS + "Troisième ligne" ; LastRow = StrGetRow(Texte, StrNumberLines(Texte)); Rapport (DernièreLigne);

Le résultat de l'exécution de ce code sera l'affichage de la ligne « Troisième ligne ».

Occurrences de numéro de page

StrNumberOccurrences(<Строка>, <ПодстрокаПоиска>) . Renvoie le nombre d'occurrences de la sous-chaîne spécifiée dans une chaîne. La fonction est sensible à la casse.

Exemple 19. Déterminez combien de fois la lettre « c » apparaît dans la ligne « Lignes en 1s 8.3 et 8.2 », quelle que soit sa casse.

Ligne = "Lignes en 1s 8.3 et 8.2" ; NombreOccurrences = StrNumberOccurrences(Vreg(String), "C"); Rapport (Nombre d'occurrences);

Le résultat de l'exécution de ce code sera l'affichage du nombre d'occurrences : 2.

PageDébutAvec

StrDébutAvec(<Строка>, <СтрокаПоиска>) . Vérifie si la chaîne passée dans le premier paramètre commence par la chaîne du deuxième paramètre.

Exemple 20. Déterminez si le NIF de la contrepartie sélectionnée commence par le chiffre 1. Introduisez la variable Contrepartie Contreparties.

TIN = Contrepartie.TIN ; StartsUNits = StrStartsWith(TIN, "1"); Si commence par des unités Alors //Votre code EndIf ;

Fin de page activée

StrEndsWith(<Строка>, <СтрокаПоиска>) . Vérifie si la chaîne passée dans le premier paramètre se termine par la chaîne du deuxième paramètre.

Exemple 21. Déterminer si le NIF de la contrepartie sélectionnée se termine par le chiffre 2. Introduire la variable Contrepartie une référence à un élément de répertoire est stockée Contreparties.

TIN = Contrepartie.TIN ; EndsWithTwo = StrEndsWith(TIN, "2"); If EndsInTwo Then //Votre code EndIf;

Fractionnement de page

StrDivide(<Строка>, <Разделитель>, <ВключатьПустые>) . Divise une chaîne en parties à l'aide des caractères délimiteurs spécifiés et écrit les chaînes résultantes dans un tableau. Le premier paramètre stocke la chaîne source, le second contient la chaîne contenant le délimiteur et le troisième indique si les chaînes vides doivent être écrites dans le tableau (par défaut Vrai).

Exemple 22. Ayons une chaîne contenant des nombres séparés par le symbole « ; », récupérons un tableau de nombres à partir de la chaîne.

Chaîne = "1 ; 2 ; 3" ; Tableau = StrDivide(Chaîne, ";"); Pour Count = 0 Par Array.Quantity() - 1 tentative de cycle Array[Count] = Number(AbbrLP(Array[Count])); Tableau d'exceptions [Sch] = 0 ; EndAttemptsEndCycle ;

À la suite de l'exécution, un tableau avec des nombres de 1 à 3 sera obtenu.

PageConnecter

StrConnect(<Строки>, <Разделитель>) . Convertit le tableau de chaînes du premier paramètre en une chaîne contenant tous les éléments du tableau séparés par le délimiteur spécifié dans le deuxième paramètre.

Exemple 23. En utilisant le tableau de nombres de l'exemple précédent, récupérez la chaîne d'origine.

Pour Account = 0 By Array.Quantity() - 1 Cycle Array[Act] = String(Array[Act]); Fin du cycle ; Ligne = StrConnect(Array, "; ");