Înlocuiți caracterele din rândul 1c. Noi funcții pentru lucrul cu șiruri. Funcție pentru lucrul cu șiruri de caractere StrFind()

25.10.2019 Știri

Rândurile din 1C 8.3 în limbajul încorporat 1C reprezintă valori de tip primitiv Linia. Valori de acest tip conține un șir Unicode de lungime arbitrară. Variabilele de tip șir sunt un set de caractere cuprinse între ghilimele.

Exemplul 1. Să creăm o variabilă șir cu text.

StringVariable = „Bună lume!”;

Funcții pentru lucrul cu șiruri în 1s 8.3

ÎN aceasta sectiune Vor fi date principalele funcții care vă permit să schimbați liniile în 1c, sau să analizați informațiile conținute în acestea.

StrLength

StrLength(<Строка>) . Returnează numărul de caractere conținut în șirul transmis ca parametru.

Exemplul 2. Să numărăm numărul de caractere din rândul „Bună lume!”

String = „Bună lume!”; NumberofCharacters = StrLength(String); Raport (NumărCaractere);

Rezultatul executării acestui cod va fi afișarea numărului de caractere din rând: 11.

AbbrL

AbbrL(<Строка>) . Decupează caracterele nesemnificative la stânga primului caracter semnificativ din șir.
Caractere mici:

  • spaţiu;
  • spatiu nerupere;
  • intabulare;
  • retur transport;
  • traducere de linie;
  • traducerea formularului (pagina).

Exemplul 3. Eliminați toate spațiile din partea stângă a liniei „lume!” și adăugați linia „Bună ziua”.

String = Abreviere ("lumea!"); String = „Bună ziua”+String; Raport (Șir);

Rezultatul executării acestui cod va fi afișarea liniei „Hello world!” pe ecran.

Abreviat

Abreviere(<Строка>) . Decupează caracterele nesemnificative la dreapta primului caracter semnificativ din șir.

Exemplul 4. Formular din rândurile „Bună ziua” și „pace!” expresia „Bună lume!”

Linie = Abreviere("Bună ziua ")+" "+ Abreviere(" lume!"); Raport (Șir);

AbbrLP

AbbrLP(<Строка>) . Decupează caracterele nesemnificative la dreapta primului caracter semnificativ din șir și, de asemenea, decupează caracterele nesemnificative la stânga primului caracter semnificativ din șir. Această funcție este folosit mai des decât precedentele două, deoarece este mai universal.

Exemplul 5. Eliminați caracterele nesemnificative din stânga și dreapta din numele contrapărții.

Counterparty = Directoare. Counterparties.Find By Details("TIN", "0777121211"); AccountObject = Account.GetObject(); CounterpartyObject.Name = AbbrLP(CounterpartyObject.Name); AccountObject.Write();

un leu

Un leu(<Строка>, <ЧислоСимволов>) . Obține primele caractere ale șirului, numărul de caractere este specificat în parametru Numărul de caractere.

Exemplul 6. Lăsați structura Angajat conțin numele, prenumele și patronimele angajatului. Obțineți un șir cu numele de familie și inițialele.

NameInitial = Lev(Employee.Name, 1); Patronimic Initial = Leu(Angajat. Patronimic, 1); FullName = Employee.LastName + " " + FirstName Initial + "." + Inițiala din mijloc + ".";

Dreapta

Dreapta(<Строка>, <ЧислоСимволов>) . Obține ultimele caractere ale unui șir, numărul de caractere specificat în parametru Numărul de caractere. Dacă numărul specificat de caractere depășește lungimea șirului, atunci întregul șir este returnat.

Exemplul 7. Lăsați o dată în formatul „aaaammzz” să fie scrisă la sfârșitul unei variabile șir, obțineți un șir cu data și convertiți-l în tip Data.

String = " Data curentă: 20170910"; StringDate = Drepturi (String, 8); Data = Data (StringDate);

miercuri

Miercuri(<Строка>, <НачальныйНомер>, <ЧислоСимволов>) . Obține un subșir din șirul transmis ca parametru Linia, începând de la caracterul al cărui număr este specificat în parametru InitialNumber iar lungimea trecută în parametru Numărul de caractere. Numerotarea caracterelor dintr-o linie începe de la 1. Dacă se află în parametru InitialNumber este specificată o valoare mai mică sau egală cu zero, atunci parametrul ia valoarea 1. Dacă parametrul Numărul de caractere nu este specificat, apoi sunt selectate caractere până la sfârșitul rândului.

Exemplul 8. Lăsați variabila șir care începe din a noua poziție să conțină codul de regiune, ar trebui să îl obțineți și să îl scrieți într-o linie separată.

String = „Regiune: 99 Moscova”; Regiune = Avg(String, 9, 2);

PageFind

StrFind(<Строка>, <ПодстрокаПоиска>, <НаправлениеПоиска>, <НачальнаяПозиция>, <НомерВхождения>) . Caută un subșir specificat într-un șir, returnând numărul de poziție al primului caracter al subșirului găsit. Să ne uităm la parametrii acestei funcții:

  • Linia. șir sursă;
  • Căutare subșir. Căutare subșir;
  • Direcția de căutare. Specifică direcția de căutare a unui subșir într-un șir. Poate lua valori:
    • Căutare Direcție. De la început;
    • Căutare.Sfârșit direcția;
  • Poziția inițială. Specifică poziția în șir de la care începe căutarea;
  • NumberOccurrence. Specifică numărul de apariție al subșirului căutat în șirul sursă.

Exemplul 9. În rândul „Bună lume!” Determinați poziția ultimei apariții a caracterului „și”.

PositionNumber = StrFind("Bună lume!", "și", SearchDirection.End); Raport (Număr Poziție);

Rezultatul executării acestui cod va fi afișarea numărului ultimei apariții a simbolului „și”: 9.

VReg

VReg(<Строка>) . Convertește toate caracterele din șirul specificat în 1s8 în majuscule.

Exemplul 10: Convertiți șirul „hello world!” la majuscule.

StringVreg = VReg("bună lume!"); Raport (StringVreg);

Rezultatul executării acestui cod va fi afișarea liniei „HELLO WORLD!”

NReg

NReg(<Строка>) . Convertește toate caracterele șirului specificat în 1s 8 în minuscule.

Exemplul 11: Convertiți șirul „HELLO WORLD!” la litere mici.

StringNreg = NReg("HELLO WORLD!"); Raport (StringVreg);

Rezultatul executării acestui cod va fi afișarea liniei „hello world!”

Treg

TReg(<Строка>) . Convertește un șir după cum urmează: primul caracter al fiecărui cuvânt este convertit în majuscule, caracterele rămase ale cuvântului sunt convertite în minuscule.

Exemplul 12. A face mai întâi cu majuscule litere de cuvinte din rândul „bună lume!”

StringTreg = TReg("bună lume!"); Raport (StringTreg);

Rezultatul executării acestui cod va fi afișarea liniei „Hello World!”

Simbol

Simbol(<КодСимвола>) . Obține un caracter prin codul său Unicod.

Exemplul 13. Adăugați la stânga și la dreapta liniei „Hello World!” simbol ★

StringWithStars = Simbol("9733")+"Bună lume!"+Simbol ("9733"); Raport (StringWithStars);

Rezultatul executării acestui cod va fi afișarea liniei „★Hello World!”

Cod simbol

CodSimbol(<Строка>, <НомерСимвола>) . Obține codul caracterului Unicode din șirul specificat în primul parametru, situat în poziția specificată în al doilea parametru.

Exemplul 14. Aflați codul ultimului caracter din rândul „Hello World!”

String = „Bună lume!”; CharacterCode = CharacterCode(String, StrLength(String)); Notify(CharacterCode);

Rezultatul executării acestui cod va fi afișarea codului simbol „!” - 33.

Linie goală

Linie goală (<Строка>) . Verifică dacă șirul constă doar din caractere nesemnificative, adică dacă este gol.

Exemplul 15. Verificați dacă un șir format din trei spații este gol.

Gol = EmptyString(" "); Raport (Gol);

Rezultatul executării acestui cod va fi afișarea cuvântului „Da” (o expresie șir de valoare logică Adevărat).

Înlocuire pagină

StrInlocuire(<Строка>, <ПодстрокаПоиска>, <ПодстрокаЗамены>) . Găsește toate aparițiile subșirului de căutare în șirul sursă și îl înlocuiește cu subșirul de înlocuire.

Exemplul 16. În rândul „Hello World!” înlocuiți cuvântul „Pace” cu cuvântul „Prieteni”.

String = StrReplace("Bună lume!", "Lumea", "Prieteni"); Raport (Șir);

Rezultatul executării acestui cod va fi afișarea liniei „Salut prieteni!”

StrNumberLines

StrNumberRow(<Строка>) . Vă permite să numărați numărul de linii dintr-un șir cu mai multe linii. A merge la linie nouăîn 1s 8 se foloseşte simbolul PS(caracter nou linie).

Exemplul 17. Determinați numărul de rânduri din text:
"Prima linie
A doua linie
A treia linie"

Number = StrNumberString("Prima linie"+Caractere.PS +"A doua linie"+Simboluri.PS +"A treia linie"); Raport (Număr);

Rezultatul executării acestui cod va fi afișarea numărului de linii din text: 3

StrGetString

StrGetString(<Строка>, <НомерСтроки>) . Obține o linie într-un șir de mai multe linii după numărul său. Numerotarea liniilor începe de la 1.

Exemplul 18. Obțineți ultima linie din text:
"Prima linie
A doua linie
A treia linie"

Text = "Prima linie" + Simboluri. PS + "A doua linie" + Simboluri. PS + "A treia linie"; LastRow = StrGetRow(Text, StrNumberLines(Text)); Raport (LastLine);

Rezultatul executării acestui cod va fi afișarea liniei „Third Line”.

PageNumberOccurrence

StrNumberOccurrences(<Строка>, <ПодстрокаПоиска>) . Returnează numărul de apariții ale subșirului specificat într-un șir. Funcția este sensibilă la majuscule și minuscule.

Exemplul 19. Determinați de câte ori apare litera „c” în linia „Linii în 1s 8.3 și 8.2”, indiferent de cazul ei.

Linie = „Linii în 1s 8.3 și 8.2”; NumberOccurrences = StrNumberOccurrences(Vreg(String), "C"); Raport (Număr Apariții);

Rezultatul executării acestui cod va fi afișarea numărului de apariții: 2.

PageStartsWith

StrStartsWith(<Строка>, <СтрокаПоиска>) . Verifică dacă șirul trecut în primul parametru începe cu șirul din al doilea parametru.

Exemplul 20. Determinați dacă TIN-ul contrapărții selectate începe cu numărul 1. Introduceți variabila Contrapartidă Contrapartide.

TIN = Counterparty.TIN; StartsUNits = StrStartsWith(TIN, "1"); If Starts with units Then //Codul dvs. EndIf;

PageEndsOn

StrEndsWith(<Строка>, <СтрокаПоиска>) . Verifică dacă șirul trecut în primul parametru se termină cu șirul din al doilea parametru.

Exemplul 21. Determinați dacă TIN-ul contrapărții selectate se termină cu numărul 2. Introduceți variabila Contrapartidă este stocată o referință la un element de director Contrapartide.

TIN = Counterparty.TIN; EndsWithTwo = StrEndsWith(TIN, „2”); If EndsInTwo Then //Codul dvs. EndIf;

PageSplit

StrDivide(<Строка>, <Разделитель>, <ВключатьПустые>) . Împarte un șir în părți folosind caracterele delimitatoare specificate și scrie șirurile rezultate într-o matrice. Primul parametru stochează șirul sursă, al doilea conține șirul care conține delimitatorul, iar al treilea indică dacă șirurile goale trebuie scrise în matrice (în mod implicit Adevărat).

Exemplul 22. Să avem un șir care conține numere separate prin simbolul „;”, obținem o matrice de numere din șir.

String = "1; 2; 3"; Array = StrDivide(String, ";"); Pentru Count = 0 By Array.Quantity() - 1 Cycle Attempt Array[Count] = Number(AbbrLP(Array[Count])); Exception Array[Sch] = 0; EndAttemptsEndCycle;

Ca rezultat al execuției, se va obține o matrice cu numere de la 1 la 3.

PageConnect

StrConnect(<Строки>, <Разделитель>) . Convertește matricea de șiruri din primul parametru într-un șir care conține toate elementele matricei separate de delimitatorul specificat în al doilea parametru.

Exemplul 23. Folosind tabloul de numere din exemplul anterior, obțineți șirul original.

Pentru cont = 0 By Array.Quantity() - 1 Cycle Array[Act] = String(Array[Act]); EndCycle; Rând = StrConnect(Matrice, "; ");

Salutare tuturor
Astăzi mi-au cerut să nu afișez prefixul documentului la tipărirea unui document de implementare, am rezolvat problema în felul următor.

StrReplace(Număr, Lev(Număr, 3), "" );

Când m-am uitat în asistentul de sintaxă, mi-a plăcut atât de mult încât am vrut să scriu despre el lucrul cu șiruri în 1C:Enterprise.

Un șir în 1C se referă la un tip de date primitiv.

Dacă te uiți la ajutorul 1C, vom vedea următoarea descriere a tipului String:
Valorile de acest tip conțin un șir Unicode de lungime arbitrară.
Dacă folosiți propriile cuvinte despre șiruri, va funcționa. Un șir este o constantă formată din diferite caractere, întotdeauna înconjurate de ghilimele.

Stabilirea unei linii
Salutare = „Bună ziua pasagerului”;

Liniile cu mai multe linii în configurații tipice sunt cel mai adesea create folosind separatorul vertical „|”:
String = „Multilinie
|șir
|scrie
|text";

Este specificat un citat în interiorul unui șir ghilimele duble.
String = ""Text între ghilimele"";

Există multe operații pe șiruri (căutarea în interiorul șirului, determinarea primelor etc.), este mai bine să te uiți la Syntax Assistant.
Ajutor de sintaxă - descriere generala limbaj încorporat -> funcții încorporate -> funcții pentru lucrul cu șiruri.

Funcții pentru lucrul cu șiruri

Iată un scurt rezumat al funcțiilor pentru lucrul cu șiruri de caractere:

VReg(<Строка>) — Funcția convertește toate caracterele din șir în majuscule.

CodSimbol(<Строка>, <НомерСимвола>) – Funcția primește codul caracterului aflat în șirul transmis la poziția cu numărul specificat.

Un leu(<Строка>, <ЧислоСимволов>) – Funcția selectează primele caractere din stânga șirului.

Găsi(<Строка>, <ПодстрокаПоиска>) — Funcția găsește o apariție a șirului de căutare ca subșir în șirul sursă.

NReg(<Строка>) — Funcția convertește toate caracterele din șir în litere mici.

Dreapta(<Строка>, <ЧислоСимволов>) – Această funcție diferă de funcțiile Left prin faptul că selectează ultimele caractere din dreapta șirului.

Linie goală (<Строка>) — Funcția verifică șirul pentru prezența caracterelor semnificative.

Simbol(<КодСимвола>) — Funcția convertește codul caracterului într-un șir care conține caracterul.

AbbrL(<Строка>) — Funcția decupează caracterele nesemnificative din stânga primului caracter semnificativ din șir.

AbbrLP(<Строка>) — Funcția decupează caracterele nesemnificative la stânga primului caracter semnificativ din linie și spațiile la dreapta ultimului caracter semnificativ din linie.

Abreviere(<Строка>) — Funcția decupează caracterele nesemnificative din dreapta ultimului caracter semnificativ din șir.

Miercuri(<Строка>, <НачальныйНомер>, <ЧислоСимволов>) — Funcția selectează un șir de caractere, începând cu caracterul<НачальныйНомер>, numărul total<ЧислоСимволов>.

StrLength(<Строка>) — Funcția primește numărul de caractere din linie.

StrInlocuire(<Строка>, <ПодстрокаПоиска>, <ПодстрокаЗамены>) — Funcția găsește toate aparițiile subșirului de căutare în șirul sursă și îl înlocuiește cu subșirul de înlocuire.

StrGetString(<Строка>, <НомерСтроки>) - Funcția primește un șir de mai multe linii după număr.

StrNumberOccurrences(<Строка>, <ПодстрокаПоиска>) — Funcția calculează numărul de apariții ale subșirului de căutare în șirul sursă.

StrNumberRow(<Строка>) — Funcția numără numărul de linii dintr-un șir cu mai multe linii. Într-un șir cu mai multe linii, liniile sunt separate prin linii noi.

TReg(<Строка>) — Funcția convertește șirul în majuscule de titlu. Aceasta înseamnă că primul caracter al fiecărui cuvânt este convertit în majuscule sau litere mari dacă nu este specificată pentru caracter. Caracterele rămase sunt convertite în litere mici.

Conversii de tip
Pentru conversia explicită a tipurilor de date, există funcții cu același nume cu tipul de date la care are loc conversia: String(<Значение>)

StringFromNumbers = String(Number);

Toate aceste funcții sunt descrise în detaliu în Syntax Assistant; am descris modul în care Syntax Assistant poate ajuta un programator începător în articol.

Exemple de lucru cu șiruri

Conversia unui număr într-un șir și înapoi.

Pentru a obține o reprezentare în șir a anului, utilizați funcția Format.

An = Format(CurrentDate(), "DF=aaaa") // An = "2012"

Pentru a converti un număr într-un șir fără a introduce un caracter separator de grup (spațiu neîntrerupt), trebuie să utilizați funcția Format cu parametrul NG=0:

Număr = 2012 Linie = Format(Număr, "NH=0" ); //Șir = „2012”

String Fără spații.

Implementat în versiunea 8.3.6.1977.

Am extins setul de funcții concepute pentru a funcționa cu șiruri. Am făcut acest lucru pentru a vă oferi instrumente mai avansate pentru analizarea datelor șirurilor. Noile funcții vor fi convenabile și utile în sarcinile tehnologice de analiză a textului. În sarcinile legate de analizarea textului care conține date în formă formatată. Aceasta ar putea fi o analiză a unor fișiere primite de la echipament sau, de exemplu, o analiză a unui jurnal tehnologic.

Puteți efectua toate acțiunile care îndeplinesc funcții noi înainte. Folosind algoritmi mai mult sau mai puțin complecși scriși într-un limbaj încorporat. Prin urmare, noile funcții nu vă oferă capabilități fundamental noi. Cu toate acestea, vă permit să reduceți cantitatea de cod și să faceți codul mai simplu și mai ușor de înțeles. În plus, vă permit să accelerați execuția acțiunilor. Pentru că funcțiile implementate în platformă funcționează, desigur, mai rapid decât un algoritm similar scris într-un limbaj încorporat.

Funcția de formatare StrTemplate()

Această funcție înlocuiește parametrii într-un șir. Necesitatea unei astfel de conversii apare adesea, de exemplu, la afișarea mesajelor de avertizare. Sintaxa pentru această funcție este următoarea:

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

<Шаблон>- acesta este șirul în care trebuie să înlocuiți reprezentările parametrilor.

<Значение1> , ... <Значение10>- sunt parametri (maximum zece), ale căror reprezentări trebuie substituite în șir.

Pentru a indica un anumit loc în șablon în care doriți să efectuați înlocuirea, trebuie să utilizați marcatori precum %1, ... %10. Numărul de markeri implicați în șablon și numărul de parametri care conțin valori trebuie să se potrivească.

De exemplu, rezultatul executării unui astfel de operator:

va fi o linie:

Eroare de date pe linia 2 (Tipul de dată este necesar)

Funcție pentru lucrul cu șiruri de caractere StrCompare()

Această funcție compară două șiruri de caractere fără a ține seama de majuscule și minuscule. De exemplu, așa:

Puteți efectua aceeași acțiune mai devreme folosind obiectul Comparație valori:

Cu toate acestea, utilizarea noii caracteristici pare mai ușoară. Și pe lângă aceasta, funcționează și funcția, spre deosebire de obiectul Value Comparison client slab, și în clientul web.

Funcții pentru lucrul cu șiruri de caractere StrStartsWith(), StrEndsAt()

Aceste funcții determină dacă un șir începe cu un subșir specificat sau dacă un șir se termină cu un subșir specificat. Algoritmul pentru aceste funcții nu este greu de implementat într-un limbaj încorporat, dar prezența lor vă permite să scrieți cod mai curat și mai ușor de înțeles. Și lucrează mai repede.

De exemplu, ele sunt convenabile de utilizat în instrucțiunea If:

Funcții pentru lucrul cu șiruri de caractere StrDivide(), StrConnect()

Aceste funcții împart un șir în părți folosind un delimitator specificat. Sau invers, combină mai multe linii într-una singură, inserând între ele separatorul selectat. Sunt convenabile pentru crearea sau analizarea jurnalelor și a revistelor tehnologice. De exemplu, puteți analiza cu ușurință o intrare de jurnal tehnologic în părți adecvate pentru analiză ulterioară:

Funcție pentru lucrul cu șiruri de caractere StrFind()

În loc de vechea funcție Find(), am implementat optiune noua, care are caracteristici suplimentare:

  • Caută în direcții diferite (de la început, de la sfârșit);
  • Căutați dintr-o poziție specificată;
  • Căutați o apariție cu un număr specificat (al doilea, al treilea etc.).

De fapt, dublează capacitățile vechii funcție. Acest lucru se face pentru a menține compatibilitatea cu modulele compilate în versiuni mai vechi. Este recomandat să nu mai folosiți vechea funcție Find().

Mai jos este un exemplu de utilizare a noilor capabilități de căutare. Căutarea inversă este utilă atunci când aveți nevoie de ultima parte a unui șir oficial, cum ar fi numele complet al fișierului într-o adresă URL. Și căutarea dintr-o poziție specificată ajută în cazurile în care trebuie să căutați într-un fragment cunoscut, și nu în întreaga linie.

Există puține mecanisme pentru a lucra cu șiruri în interogările 1C. În primul rând, liniile pot fi adăugate. În al doilea rând, puteți lua un subșir dintr-un șir. În al treilea rând, șirurile pot fi comparate, inclusiv după model. Asta este probabil tot ce se poate face cu șiruri.

Adăugarea șirurilor

Pentru a adăuga rânduri într-o interogare, se utilizează operația „+”. Puteți adăuga doar șiruri de lungime limitată.

SELECTAȚI „Nume: ” + Contrapărți. Nume AS Coloana 1 DIN Director. Contrapărți AS Contrapărți WHERE Contrapărți. Link = &Link

Funcția subșir

SUBSTRING(<Строка>, <НачальнаяПозиция>, <Длина>)

Un analog al funcției Environment() din modelul obiect. Funcția Substring() poate fi aplicată datelor șirului și vă permite să selectați un fragment <Строки> , începând cu numărul caracterului <НачальнаяПозиция> (caracterele dintr-o linie sunt numerotate începând de la 1) și lungime <Длина> personaje. Rezultatul calculului funcției are un tip de șir de lungime variabilă, iar lungimea va fi considerată nelimitată dacă <Строка> are lungime și parametri nelimitați <Длина> nu este o constantă sau mai mare decât 1024.

Dacă lungimea șirului este mai mică decât cea specificată în al doilea parametru, atunci funcția va returna un șir gol.

Atenţie! Utilizarea funcției SUBSTRING() pentru a converti șiruri de lungime nelimitată în șiruri de lungime limitată nu este recomandată. În schimb, este mai bine să utilizați operatorul de distribuție EXPRESS().

Funcție similară

Dacă trebuie să ne asigurăm că un atribut șir îndeplinește anumite criterii, îl comparăm:

SELECTARE Counterparties. Nume AS Coloana 1 FROM Directory. Counterparties AS Counterparties WHERE Contrapartide. Nume = "Gazprom"

Dar dacă ai nevoie de o comparație mai subtilă? Nu doar egalitate sau inegalitate, ci asemănarea cu un anumit tipar? Exact pentru asta a fost creată funcția SIMILAR.

LIKE — Operator pentru verificarea asemănării unui șir cu un model. Analog de LIKE în SQL.

Operatorul SIMILAR vă permite să comparați valoarea expresiei specificate în stânga acesteia cu șirul de model specificat în dreapta. Valoarea expresiei trebuie să fie de tip șir. Dacă valoarea expresiei se potrivește cu modelul, rezultatul operatorului va fi TRUE, în caz contrar va fi FALS.

Următoarele caractere din șirul șablon sunt caractere de serviciu și au o semnificație diferită de caracterul șir:

  • % (procent): o secvență care conține orice număr de caractere arbitrare;
  • _ (subliniere): un caracter arbitrar;
  • […] (V paranteza patrata unul sau mai multe caractere): orice caracter unic enumerat între paranteze pătrate. Enumerarea poate conține intervale, de exemplu a-z, adică un caracter arbitrar inclus în interval, incluzând capetele intervalului;
  • [^...] (în paranteze drepte un semn de negație urmat de unul sau mai multe caractere): orice caracter unic, altul decât cele enumerate după semnul de negație.

Orice alt simbol înseamnă el însuși și nu poartă nicio sarcină suplimentară. Dacă unul dintre caracterele enumerate trebuie să fie scris ca el însuși, atunci trebuie să fie precedat de<Спецсимвол>. Eu insumi<Спецсимвол>(orice simbol adecvat) este definit în aceeași declarație după cuvânt cheie SIMBOL SPECIAL.

Tipul String se găsește în toate limbajele de programare. Este primitiv, iar în 1C există multe funcții pentru a lucra cu el. În acest articol vom arunca o privire mai atentă diferite căi lucrul cu tipuri de șiruri din 1C 8.3 și 8.2 folosind exemple.

Linia

Pentru a converti o variabilă de orice tip într-un șir, există o funcție cu același nume „String()”. Parametrul de intrare va fi variabila însăși, a cărei reprezentare în șir trebuie obținută.

String(False) // returnează „Nu”
String(12345) // returnează „12.345”
String(CurrentDate()) //"07/21/2017 11:55:36″

Este posibil să convertiți nu numai tipurile primitive într-un șir, ci și altele, de exemplu, elemente de directoare și documente.

SokrLP, SokrL, SokrP

Parametrii de intrare ai acestor funcții sunt o variabilă de tip șir. Funcțiile îndepărtează caractere nesemnificative (spații, întoarceri de căruță etc.): din stânga și din dreapta, doar din stânga și, respectiv, numai din dreapta.

Abreviere ("Spațiile vor fi eliminate pe ambele părți") // "Spațiile vor fi eliminate pe ambele părți"
Abreviere(" Spațiile de pe ambele părți vor fi eliminate ") // " Spațiile din stânga vor fi eliminate "
Abreviere ("Spațiile de pe ambele părți vor fi eliminate") // "Spațiile din dreapta vor fi eliminate"

Leu, corect, mediu

Aceste funcții vă permit să tăiați o parte dintr-un șir. Funcția „Left()” va returna porțiunea unui șir din partea stângă a lungimii specificate. Funcția „Dreapta()” este similară, dar decupează din dreapta. Funcția „Avg()” vă permite să specificați numărul caracterului din care va fi selectată linia și lungimea acestuia.

Lev(„variabilă șir”, 4) // returnează „Str”
Dreapta(„variabilă șir”, 7) // returnează „variabilă”
Mediu(„variabilă șir”, 2, 5) // returnează „troco”

StrLength

Funcția determină numărul de caractere care sunt conținute într-o variabilă șir.

StrLength("Cuvânt") // rezultatul execuției va fi numărul 5

Găsi

Funcția face posibilă căutarea unei părți dintr-un șir într-o variabilă șir. Valoarea returnată va fi un număr care arată poziția începutului șirului găsit. Dacă nu se găsește nicio potrivire, se returnează zero.

Vă rugăm să rețineți că căutarea face distincție între majuscule și minuscule. Dacă există mai mult de o apariție a subșirului de căutare în șirul original, funcția va returna începutul primei apariții.

Find("unu, doi, unu, doi, trei", "două") // funcția va returna numărul 6

Linie goală

Utilizarea acestei funcții vă permite să determinați dacă un șir este gol. Caracterele minore, cum ar fi spațiul, întoarcerea căruciorului și altele, nu sunt luate în considerare.

EmptyString(„Pukin Vasily Ivanovich”) // va returna valoarea False
EmptyString(" ") // va returna valoarea True

VReg, NReg, TReg

Aceste funcții sunt foarte utile atunci când se compară și se convertesc variabile șir. „Vreg()” va returna șirul original în majuscule, „НReg()” este în partea de jos, iar „TReg()” îl va formata astfel încât primul caracter al fiecărui cuvânt individual să fie scris cu majuscule, iar toate cele ulterioare vor fi scrise cu majuscule.

VReg("DIRECTOR GENERAL") // returnează valoarea - "DIRECTOR GENERAL"
NReg(„CEO DIRECTOR”) // returnează valoarea – „CEO”
TREG(„CEO DIRECTOR”) // returnează valoarea – „Director general”

Înlocuire pagină

Această funcție este analogă cu înlocuirea în editori de text. Vă permite să înlocuiți un caracter sau un set de caractere cu altul în variabile șir.

StrReplace("rosu, alb, galben", ","", ";") // returneaza "rosu; alb; galben"

StrNumberLines

Funcția vă permite să determinați numărul de linii separate prin returnări de transport într-o variabilă text.

Bucla din exemplul de mai jos va trece prin trei runde, deoarece funcția LineNumberRow va returna valoarea 3:

Pentru ind = 1 prin StrNumărul șirurilor de caractere ("Line1" + Symbols.PS + "Line2" + Symbols.PS + "Line3") Cicl
<тело цикла>
EndCycle;

StrGetString

Această funcție funcționează cu textul cu mai multe linii în același mod ca și cea anterioară. Vă permite să obțineți un șir specific dintr-o variabilă text.

StrGetString(„Șir1” + Caractere.PS + „Șir2” + Caractere.PS + „Șir3”, 2) // returnează „String2”

PageNumberOccurrence

Funcția numără numărul de apariții ale unui caracter sau subșir în șirul de căutare.

StrNumberAttachments("a;b;c;d; ", ";") // funcția va returna numărul 4

Simbol și cod de simbol

Aceste funcții vă permit să obțineți un caracter prin codul său în codificarea Unicode, precum și să determinați acest cod prin caracterul însuși.

SymbolCode("A") // funcția va returna numărul 1.040
CharacterCode(1040) // funcția va returna „A”

Sarcini comune atunci când lucrați cu șiruri

Concatenarea șirurilor

Pentru a combina mai multe șiruri (pentru a efectua concatenarea), este suficient să folosiți operatorul de adăugare.

„Linia 1″ + „Linia 2″ //rezultatul adăugării a două linii va fi „Linia 1 Linia 2”

Conversie tip

Pentru a converti un tip într-un șir, de exemplu, o legătură către un element de director, un număr etc., este suficient să folosiți funcția „String()”. Funcții precum „ScrLP()” vor converti, de asemenea, variabilele într-un șir, dar imediat cu tăierea caracterelor nesemnificative.

String(1000) // returnează „1.000”

Vă rugăm să rețineți că atunci când convertiți un număr într-un șir, programul a adăugat automat un spațiu care separă mie. Pentru a evita acest lucru, puteți utiliza următoarele construcții:

StrReplace(String(1000),Characters.NPP,"") // returnează "1000"

String(Format(1000,"HG=")) // returnează "1000"

Citate într-un șir

Destul de des va trebui să vă confruntați cu necesitatea de a specifica ghilimele într-o variabilă șir. Acesta poate fi fie textul cererii scris în configurator, fie doar o variabilă. Pentru a rezolva această problemă, trebuie doar să setați două ghilimele.

Antet = String("Horns and Hooves LLC - asta suntem noi!") // va returna "Horns and Hooves LLC - asta suntem noi!"

Multi-linie, întrerupere de linie

Pentru a crea text cu mai multe linii, trebuie doar să adăugați rupturi de linie (Symbols.PS).

MultilineText = „Prima linie” + Simboluri.PS + „A doua linie”

Cum să eliminați spațiile

Pentru a elimina spațiile din dreapta sau din stânga, puteți folosi funcția „ScrAP()” (precum și „ScrL()” și „ScrP()”):

StringNoSpaces = Abreviere ("Multe litere") // funcția va returna valoarea "Multe litere"

Dacă după convertirea unui număr într-un șir, trebuie să eliminați spatii nerupere, utilizați următoarea construcție:

StringNoSpaces = StrReplace(String(99999),Characters.NPP,"") // returnează "99999"

De asemenea, programatorii folosesc adesea următoarea construcție, care vă permite să eliminați sau să înlocuiți cu un alt caracter toate spațiile dintr-o variabilă text:

StringNoSpaces = StrReplace("hello","") // returnează "hello"

Compararea șirurilor între ele

Puteți compara termenii cu semnul egal obișnuit. Comparația face distincție între majuscule și minuscule.

"Hello" = "bună ziua" // returnează False
"Hello" = "Bună ziua" // returnează True
„Hello” = „La revedere” // va returna False