Section courante

A propos

Section administrative du site

 Langage  Installation  Elément  Tutoriel  Programmation  Bibliothèque  Cadre d'application  SDK  Gabarit  Projet  IDE  Outils  Annexe  Aide 
ABAP/4
Ada
Assembleur
Assembly & bytecode
ASP (Active Server Pages)
Basic
C
C++
C# (C Sharp)
Cobol
ColdFusion
Fortran
HTML
Java
JavaScript
LISP
Logo
LotusScript
Oberon
Pascal
Perl
PHP
PL/1
Prolog
Python
Rebol
REXX
Ruby
Rust
SAS
NoSQL
SQL
Swift
X++ (Axapta)
GNAT
SMALLAda
VHDL
Assembleur 370
Assembleur 1802
Assembleur 4004
Assembleur 6502
Assembleur 6800
Assembleur 68000
Assembleur 8080 et 8085
Assembleur 8089
Assembleur 80x86
Assembleur AGC4
Assembleur ARM
Assembleur DPS 8000
Assembleur i860
Assembleur Itanium
Assembleur MIPS
Assembleur PDP-11
Assembleur PowerPC
Assembleur RISC-V
Assembleur SPARC
Assembleur SuperH
Assembleur UNIVAC I
Assembleur VAX
Assembleur Z80
Assembleur Z8000
Assembleur z/Architecture
ASSEMBLER/MONITOR 64
Micol Assembler
GFA Assembler
A86
MASM (Macro Assembler)
TASM (Turbo Assembler)
CIL
Jasmin
LLVM
MSIL
Parrot
P-Code (PCode)
SWEET16
G-Pascal
ASP 1.0
ASP 2.0
ASP 3.0
ASP.NET
ASP.NET Core
ABasiC (Amiga)
Adam SmartBASIC
Altair BASIC
AmigaBASIC (Amiga)
AMOS Basic (Amiga)
Atari Basic (Atari 400, 600 XL, 800, 800XL)
Basic Apple II (Integer BASIC/APPLESOFT)
Basic Commodore 64 (CBM-BASIC)
Basic Commodore 128 (BASIC 7.0)
Basic Commodore VIC-20 (CBM-BASIC 2.0)
Basic Coco 1 (Color Basic)
Basic Coco 2 (Extended Color Basic)
Basic Coco 3 (Extended Color Basic 2.0)
BASICA (PC DOS)
Basic Pro
BBC BASIC
Blitz BASIC (Amiga)
DarkBASIC
Dartmouth BASIC
GFA-Basic (Atari ST/Amiga)
GWBASIC (MS-DOS)
Liberty BASIC
Locomotive BASIC (Amstrad CPC)
MSX-Basic
Omikron Basic (Atari ST)
Oric Extended Basic
Power Basic
Quick Basic/QBasic (MS-DOS)
Sinclair BASIC (ZX80, ZX81, ZX Spectrum)
ST BASIC (Atari ST)
Turbo Basic
Vintage BASIC
VBScript
Visual Basic (VB)
Visual Basic .NET (VB .NET)
Visual Basic pour DOS
Yabasic
BeckerBASIC
SIMONS' BASIC
Basic09 d'OS-9
Disk Extended Color Basic
Basic09 d'OS-9
Disk Extended Color Basic
Access
Excel
Visual Basic pour Windows
Visual Basic .NET pour Windows
C Shell Unix (csh)
C pour Amiga
C pour Atari ST
C pour DOS
C pour Falcon030
C pour GEMDOS (Atari ST)
C pour Linux
C pour PowerTV OS
C pour OS/2
C pour Unix
C pour Windows
Aztec C
CoCo-C
GNU C
HiSoft C
IBM C/2
Introl-C
Lattice C
Microsoft C
MinGW C
MSX-C
Open Watcom C
OS-9 C Compiler
Pure C
Quick C
Turbo C
HiSoft C for Atari ST
HiSoft C for CP/M (Amstrad CPC)
C++ pour OS/2
C++ pour Windows
Borland C++
C++Builder
IBM VisualAge C++
Intel C++
MinGW C++
Open Watcom C++
Symantec C++
Turbo C++
Visual C++
Visual C++ .NET
Watcom C++
Zortech C++
C# (C Sharp) pour Windows
Apple III Cobol
Microsoft Cobol
BlueDragon
Lucee
OpenBD
Railo
Smith Project
Microsoft Fortran
WATFOR-77
CSS
FBML
Open Graph
SVG
XML
XSL/XSLT
LESS
SASS
GCJ (GNU)
JSP
Jython
Visual J++
Node.js
TypeScript
AutoLISP
ACSLogo
LotusScript pour Windows
Amiga Oberon
Oberon .NET
Apple Pascal
Delphi/Kylix/Lazarus
Free Pascal
GNU Pascal
HighSpeed Pascal
IBM Personal Computer Pascal
Lisa Pascal
Maxon Pascal
MPW Pascal
OS-9 Pascal
OSS Personal Pascal
Pascal-86
Pascal du Cray Research
Pascal/VS
Pascal-XT
PURE Pascal
QuickPascal
RemObjets Chrome
Sun Pascal
THINK Pascal
Tiny Pascal (TRS-80)
Turbo Pascal
UCSD Pascal
VAX Pascal
Virtual Pascal
Turbo Pascal for CP/M-80
Turbo Pascal for DOS
Turbo Pascal for Macintosh
Turbo Pascal for Windows
CodeIgniter (Cadre d'application)
Drupal (Projet)
Joomla! (Projet)
Phalanger (PHP .NET)
phpBB (Projet)
Smarty (balise)
Twig (balise)
Symfony (Cadre d'application)
WordPress (Projet)
Zend (Cadre d'application)
PL360
PL/M-80
PL/M-86
Turbo Prolog
CPython
IronPython
Jython
PyPy
AREXX
Regina REXX
JMP
Btrieve
Cassandra
Clipper
CouchDB
dBASE
Hbase
Hypertable
MongoDB
Redis
Access
BigQuery
DB2
H2
Interbase
MySQL
Oracle
PostgreSQL
SAP HANA
SQL Server
Sybase
U-SQL
Visual C# 2005 Express
Visual Studio .NET 2003
Visual Studio 2005
Visual Studio 2008
Visual Studio 2010
Visual Studio 2012
Visual Studio 2013
Visual Studio 2015
Visual Studio 2017
Visual Studio 2019
Introduction
Les remarques
Les opérateurs
Les instructions conditionnelles
Les instructions de boucles
Les instructions d'exceptions
Type de données élémentaires
Définition de variables
Définitions de tableaux
Requêtes de données (LINQ)
Référence des mots réservés
Référence des espaces de nom (Namespace)
Les classes
Références des classes
Directives de préprocesseur C#
Les nombres
Les chaines de caractères
Date et heure
Vue par catégorie
Les interfaces
Les classes abstraites
Les classes scellés
Les indexeurs
Les premiers pas
Les fondements de C#
Les types primitifs et variables
Les opérateurs et les expressions
Les entrées/sorties de la console
Les déclarations conditionnelles
Les déclarations de boucles
Les systèmes numériques
Traitement des chaînes de caractères et du texte
WinForms (Windows Forms)
Les opérations
Conversion de string à int
Bonjour
Astronomie
Base de données
Biochimie
Chaine de caractères
Electricité
Finance
Géographie
Géométrie
Gouvernement
Histoire
Mathématique
Médicale
Météorologie
Océanographie
Sport
Système d'exploitation
Temps
Tri
Trigonométrie
Validation
Phase lunaire
Table SQL Server
Calcul du calcium corrigé
Calcul le taux d'alcoolémie
Nombre réel avec un certain nombre de décimal
Majuscule (strtoupper ou UpperCase)
Minuscule (strtolower ou LowerCase)
Calcul du tarif d'une piscine pour 1 mois
IPaymt/Interet
NPer
PPaymt/Principal
Distance en Km entre deux longitudes et latitudes
Aire d'un cercle
Aire d'une surface de prisme rectangulaire
Aire d'un triangle
Distance entre deux points
Taxe de vente canadienne
Chiffre romain
Ackermann
Exp
Factoriel
Fibonacci
Log
Nombre premier
Odd
Random
Sqrt
Triangle Pascal
Valeur absolue (ABS)
Hauteur utérine
Unité de mesure
Fréquence des vagues
Hockey
Variables d'environnement
Année bissextile
Date de la Pâque
Heure courante
FirstDayOfMonth
Tri à bulle (Bubble Sort)
Tri Shell Sort
ArcCos
ArcSin
Atn/ATan/ArcTan/ArcTangente
Cos
Sin
Courriel
ALGLIB
Dapper
ElmahCore
FluentFTP
log4net
MailKit
MediatR
MimeKit
Newtonsoft.Json (Json.NET)
Serilog
.NET
.NET Core
.NET Framework
Accord.NET Framework
Akka.NET
ASP.NET
ASP.NET Core
Avalonia UI
Blazor
Entity Framework
Entity Framework Core (EF Core)
Hangfire
Infer.NET
MAUI
ML.NET
Mono
NHibernate
NUnit
Unity
xUnit.net
Azure SDK for .NET
AWS SDK for .NET
Bot Framework SDK
Razor
Umbraco
Rider
Visual Studio
Visual Studio Code
Visual C# 2005 Express
Xamarin Studio
Visual Studio .NET
Visual Studio .NET 2003
Visual Studio 2005
Visual Studio 2008
Visual Studio 2010
Visual Studio 2012
Visual Studio 2013
Visual Studio 2015
Visual Studio 2017
Visual Studio 2019
Visual Studio 2022
ELMAH
elmah.io
MS Build Tools
NuGet
WiX Toolset
Add-in Express
csc (C# Compiler)
CFF Explorer
IL DASM
ILMerge
.NET Reflector
Salamander .NET Decompiler
Références des codes d'erreur du C# (C Sharp)
Base de connaissances
Conventions de nommage
Vocabulaire
Marqueurs
Archives de paquet externe
Bibliographie
Préface
Notes légal
Dictionnaire
Recherche

Conversion de string à int

En langage de programmation C#, vous pouvez convertir une représentation sous forme de chaîne de caractères (string) d'un nombre en un entier (int) en utilisant les méthodes suivantes :

Méthode Parse

Les méthodes Parse() sont disponibles pour tous les types de données primitifs. C'est le moyen le plus simple de convertir une chaîne de caractères string en entier int. Les méthodes Parse sont disponibles pour les types d'entiers signés 16, 32, 64 bits :

La syntaxe est la suivante :

Parse(string s)
Parse(string s, NumberStyles style)
Parse(String s, NumberStyles style, IFormatProvider provider)

Il faut jusqu'à 3 paramètres, une chaîne de caractères étant obligatoire pour convertir la chaîne de caractères (string) au format entier (int), le deuxième paramètre contient le style de nombre spécifiant le style du nombre à représenter et le troisième paramètre représente le format spécifique à la culture de la chaîne de caractères.

L'exemple suivant illustre la conversion de chaînes de caractères numériques en nombres entiers :

  1. using System;
  2. using System.Globalization;
  3.           
  4. public class Program {
  5.      public static void Main() {
  6.          var int1 = Int16.Parse("100");                                                                   // Retourne 100
  7.          var int2 = Int16.Parse("(100)", NumberStyles.AllowParentheses);                                  // Retourne -100
  8.          var int3 = int.Parse("30,000", NumberStyles.AllowThousands, new CultureInfo("fr-ca"));           // Retourne 30000
  9.          var int4 = int.Parse("$ 10000", NumberStyles.AllowCurrencySymbol);                               // Retourne 10000
  10.          var int5 = int.Parse("-100", NumberStyles.AllowLeadingSign);                                     // Retourne -100
  11.          var int6 = int.Parse(" 100 ", NumberStyles.AllowLeadingWhite | NumberStyles.AllowTrailingWhite); // Retourne 100
  12.          var int7 = Int64.Parse("2147483649");                                                            // Retourne 2147483649
  13.      }
  14. }

Comme vous pouvez le voir dans l'exemple ci-dessus, une chaîne de caractères numérique valide peut être convertie en un entier. La méthode Parse() permet la conversion de la chaîne de caractères numérique dans différents formats en un entier à l'aide de l'énumération NumberStyles, par exemple une chaîne de caractères avec des parenthèses, une chaîne de caractères numérique spécifique à la culture, avec un symbole monétaire,...

Cependant, la chaîne de caractères passée doit être une chaîne numérique valide ou dans l'intervalle du type sur lequel elles sont appelées. Les instructions suivantes lèvent des exceptions.

  1. using System;
  2.                          
  3. public class Program {
  4.      public static void Main() {
  5.          var int1 = int.Parse(null);       // Déclenche FormatException
  6.          var int2 = int.Parse("");         // Déclenche FormatException
  7.          var int3 = int.Parse("100.00");   // Déclenche FormatException
  8.          var int4 = int.Parse( "100a");    // Déclenche FormatException
  9.          var int5 = int.Parse(2147483649); // Déclenche une exception de débordement en utilisant Int64.Parse()
  10.      }
  11. }

Classe Convert

Une autre façon de convertir une chaîne de caractères en entier consiste à utiliser la classe statique Convert. La classe Convert comprend différentes méthodes convertissant le type de données de base en un autre type de données de base. La classe Convert inclut les méthodes suivantes pour convertir de différents types de données en type int :

La méthode Convert.ToInt16() renvoie l'entier 16 bits, par exemple. Bref, le Convert.ToInt32() renvoie des entiers 32 bits, par exemple int et Convert.ToInt64() renvoie l'entier 64 bits, par exemple long.

  1. using System;
  2.                          
  3. public class Program {
  4.      public static void Main() {
  5.          var int1 = Convert.ToInt16("100");              // Retourne un short
  6.          var int2 = Convert.ToInt16(null);                     // Retourne un 0
  7.          var int3 = Convert.ToInt32("233300");           // Retourne int
  8.          var int4 = Convert.ToInt32("1234",16);          // Retourne 4660 - Hexadécimal de 1234
  9.          var int5 = Convert.ToInt64("1003232131321321"); // Retourne long
  10.            // Lèves des exceptions :
  11.          var int6 = Convert.ToInt16("");                 // Déclenche FormatException
  12.          var int7 = Convert.ToInt32("30,000");           // Déclenche FormatException
  13.          var int8 = Convert.ToInt16("(100)");            // Déclenche FormatException
  14.          var int9 = Convert.ToInt16("100a");             // Déclenche FormatException
  15.          var int10 = Convert.ToInt16(2147483649);        // Déclenche OverflowException
  16.      }
  17. }

Méthode TryParse

Les méthodes TryParse() sont disponibles pour tous les types primitifs afin de convertir la chaîne de caractères en type de données appelant. C'est la méthode recommandée pour convertir une chaîne de caractères (string) en un entier (int).

La méthode TryParse() convertit la représentation sous forme de chaîne de caractères d'un nombre en son équivalent entier signé 16, 32 et 64 bits. Il renvoie un booléen indiquant si la conversion a réussi ou échoué et donc il ne lève jamais d'exceptions. Les méthodes TryParse() sont disponibles pour tous les types entiers :

La syntaxe est la suivante :

bool Int32.TryParse(string s, out int result)
bool Int32.TryParse(string s, NumberStyle style, IFormatProvider provider, out int result)

La méthode TryParse() prend 3 paramètres identiques à la méthode Parse() ayant la même fonctionnalité. L'exemple suivant illustre la méthode TryParse() :

  1. using System;
  2.                          
  3. public class Program {
  4.      public static void Main() {
  5.         string numberStr = "123456";
  6.         int number;
  7.  
  8.         bool isParsable = Int32.TryParse(numberStr, out number);
  9.  
  10.         if (isParsable) Console.WriteLine(number);
  11.                    else Console.WriteLine("Impossible d'analyser.");
  12.                        
  13.      }
  14. }

L'exemple suivant illustre la conversion d'une chaîne de caractères numérique non valide :

  1. using System;
  2.                          
  3. public class Program {
  4.      public static void Main() {
  5.           string numberStr = "123456as";
  6.         int number;
  7.  
  8.         bool isParsable = Int32.TryParse(numberStr, out number);
  9.         if (isParsable) Console.WriteLine(number);
  10.                    else Console.WriteLine("Impossible d'analyser.");
  11.                        
  12.      }
  13. }

Dans l'exemple ci-dessus, numberStr = "123456as" étant une chaîne de caractères numérique non valide. Cependant, la méthode Int32.TryParse() renverra false au lieu de lever une exception. Ainsi, la méthode TryParse() est le moyen le plus sûr de convertir une chaîne de caractères numérique en type entier lorsque nous ne savons pas si la chaîne de caractères est une chaîne de caractères numérique valide ou non.



PARTAGER CETTE PAGE SUR
Dernière mise à jour : Mercredi, le 29 décembre 2021