Ugrás a tartalomra

Hogyan lehet felsorolni az összes dátumot két dátum között az Excelben?

Bizonyos esetekben, ha megadja a kezdő és a befejező dátumot, előfordulhat, hogy fel kell sorolnia az összes dátumot az Excel két e dátum között. Ez az oktatóanyag az Excel két dátum közötti összes dátumának felsorolásának módszereiről szól.

Sorolja fel az összes dátumot két dátum között képletek szerint

Sorolja fel az összes dátumot két dátum között a VBA szerint

A Kutools for Excel által két dátum közötti összes dátum listázása jó ötlet3


Itt bemutatok olyan képleteket, amelyek gyorsan felsorolhatják az összes dátumot két megadott dátum között az Excelben.

1. Írja be a kezdő és a befejező dátumot két cellába, itt beírom az A1 és A2 cellába. Lásd a képernyőképet:
doc-list-all-date-two-date-1

2. Ezután lépjen a C1 cellába, hogy beírja ezt a képletet = A1 + 1 bele, majd kattintson belép kulcs. Lásd a képernyőképet:
doc-list-all-date-two-date-2

3. Ezután írja be a C2 cellába ezt a képletet =IF($A$1+ROW(A1)>=$A$2-1,"",C1+1) bele, majd húzza le az automatikus kitöltő fogantyút a cellákra, amíg egy üres cella meg nem jelenik. Képernyőképek megtekintése:

doc-list-all-date-two-date-3       doc-list-all-date-two-date-4

Ezután láthatja az összes dátumot, amelyek két megadott dátum között szerepelnek az oszlopban.
doc-list-all-date-two-date-5

Jegyzet:

A fenti képletekben A1 a kezdő dátum, A2 a befejezés dátuma, és C1 az első dátum a dátumtartomány között.


Ha érdekel a makrokód, akkor az alábbi VBA segítségével felsorolhatja az összes dátumot az Excel két megadott dátuma között.

1. Írja be a kezdő és a befejező dátumot két cellába, itt gépelem be az A1 és a B1 cellát. Lásd a képernyőképet:
doc-list-all-date-two-date-6

2. nyomja meg Alt + F11 gombokat a megnyitáshoz Microsoft Visual Basic for Applications ablak.

3. Ezután kattintson betétlap > Modulok és másolja és illessze be a VBA kód alá a poppingba Modulok ablak.

VBA: Sorolja fel az összes dátumot két dátum között.

Sub WriteDates()
	'Updateby20150305
	Dim rng As Range
	Dim StartRng As Range
	Dim EndRng As Range
	Dim OutRng As Range
	Dim StartValue As Variant
	Dim EndValue As Variant
	xTitleId     = "KutoolsforExcel"
	Set StartRng = Application.Selection
	Set StartRng = Application.InputBox("Start Range (single cell):", xTitleId, StartRng.Address, Type: = 8)
	Set EndRng   = Application.InputBox("End Range (single cell):", xTitleId, Type: = 8)
	Set OutRng   = Application.InputBox("Out put to (single cell):", xTitleId, Type: = 8)
	Set OutRng   = OutRng.Range("A1")
	StartValue   = StartRng.Range("A1").Value
	EndValue     = EndRng.Range("A1").Value
	If EndValue - StartValue <= 0 Then
		Exit Sub
		End If
		ColIndex = 0
		For i = StartValue To EndValue
			OutRng.Offset(ColIndex, 0) = i
			ColIndex = ColIndex + 1
		Next
	End Sub

4. kettyenés futás or F5 a VBA futtatásához, és megjelenik egy párbeszédpanel, ahol kiválaszthatja a kezdési dátumot, majd kattintson a gombra OK, majd a második felbukkanó párbeszédpanelen válassza ki a befejezés dátumát. Lásd a képernyőképet:

doc-list-all-date-two-date-7          doc-list-all-date-two-date-8

5. kettyenés OK, majd válasszon egy cellát a dátumok kitöltéséhez, majd kattintson a gombra OK. Most láthatja a két dátum közötti összes dátumot. Képernyőképek megtekintése:

doc-list-all-date-two-date-9         doc-list-all-date-two-date-10

Megjegyzések: Az ezen VBA által létrehozott lista tartalmazza a kezdő és a befejező dátumot.


Valójában, ha telepítette Kutools az Excel számára - egy praktikus kiegészítő eszköz, használhatja a Véletlen adatok beillesztése hogy megoldja ezt a problémát.

Kutools az Excel számára, Több mint 300 praktikus Excel funkciók, növelheti munka hatékonyságát és megtakaríthatja munkaidejét.

Után ingyenes telepítés Kutools for Excel, kérjük, tegye a következőket:

1. Jelöljön ki egy oszlopot, amelybe két dátum közé kívánja sorolni a dátumokat, majd kattintson Kutools > betétlap > Véletlen adatok beillesztése. Lásd a képernyőképet:
doc szúrjon be véletlenszerű adatokat 1

2. Ezután a Véletlen adatok beillesztése párbeszédpanelen kattintson a gombra találka fülre, majd válassza ki a kezdő és befejező dátumot a Tól től és a To listázza, majd ne felejtse el ellenőrizni Munkanap, hétvége és a Egyedi értékek jelölőnégyzeteket. Lásd a képernyőképet:
doc-list-all-date-two-date-12

3. kettyenés Ok a párbeszédpanel bezárásához, és egy másik Kutools az Excel számára megjelenik a párbeszédpanel, csak kattintson Igen. Ezután láthatja a kezdő és a befejező dátum közötti dátumokat. Képernyőképek megtekintése:

doc-list-all-date-two-date-13           doc-list-all-date-two-date-14

4. Most rendeznie kell a dátumlistát a kívánt sorrendben. Kattintson a gombra dátum > Rendezés a legrégebbről a legújabbra. Ekkor láthatja, hogy a dátumok a legrégebbi és a legújabb dátum között vannak rendezve. Képernyőképek megtekintése:

doc-list-all-date-two-date-15          doc-list-all-date-two-date-16

A Véletlen adatok beillesztése segédprogram, akkor véletlenszerű egész számot, véletlenszerű karakterláncot és véletlenszerű időt is beszúrhat. Kattintson ide, ha többet szeretne megtudni a véletlenszerű adatok beszúrásáról.


Relatív cikkek:


A legjobb irodai hatékonyságnövelő eszközök

🤖 Kutools AI Aide: Forradalmasítsa az adatelemzést a következők alapján: Intelligens végrehajtás   |  Kód létrehozása  |  Hozzon létre egyéni képleteket  |  Adatok elemzése és diagramok létrehozása  |  A Kutools funkciók meghívása...
Népszerű szolgáltatások: Ismétlődések keresése, kiemelése vagy azonosítása   |  Üres sorok törlése   |  Oszlopok vagy cellák kombinálása adatvesztés nélkül   |   Kerek Formula nélkül ...
Szuper keresés: Több kritérium VLookup    Többértékű VLookup  |   VLookup több munkalapon   |   Fuzzy Lookup ....
Speciális legördülő lista: Gyors legördülő lista létrehozása   |  Függő legördülő lista   |  Többszörösen válassza ki a legördülő listát ....
Oszlopkezelő: Adjon meg egy adott számú oszlopot  |  Oszlopok mozgatása  |  Kapcsolja be a Rejtett oszlopok láthatósági állapotát  |  Tartományok és oszlopok összehasonlítása ...
Kiemelt funkciók: Rács fókusz   |  Design nézet   |   Nagy Formula bár    Munkafüzet és lapkezelő   |  Erőforrás-könyvtár (Auto szöveg)   |  Dátumválasztó   |  Kombinálja a munkalapokat   |  Cellák titkosítása/dekódolása    E-mailek küldése listánként   |  Szuper szűrő   |   Speciális szűrő (félkövér/dőlt/áthúzott szűrés...) ...
A 15 legjobb eszközkészlet12 szöveg Eszközök (Szöveg hozzáadása, Karakterek eltávolítása,...)   |   50 + Táblázatos Típusai (Gantt-diagram,...)   |   40+ Praktikus képletek (Számolja ki az életkort a születésnap alapján,...)   |   19 beszúrás Eszközök (Helyezze be a QR-kódot, Kép beszúrása az útvonalból,...)   |   12 Átalakítás Eszközök (Számok szavakig, Valuta átváltás,...)   |   7 Egyesítés és felosztás Eszközök (Haladó kombinált sorok, Hasított sejtek,...)   |   ... és több

Töltsd fel Excel-készségeidet a Kutools for Excel segítségével, és tapasztald meg a még soha nem látott hatékonyságot. A Kutools for Excel több mint 300 speciális funkciót kínál a termelékenység fokozásához és az időmegtakarításhoz.  Kattintson ide, hogy megszerezze a leginkább szükséges funkciót...

Leírás


Az Office lap füles felületet hoz az Office-ba, és sokkal könnyebbé teszi a munkáját

  • Füles szerkesztés és olvasás engedélyezése Wordben, Excelben és PowerPointban, Publisher, Access, Visio és Project.
  • Több dokumentum megnyitása és létrehozása ugyanazon ablak új lapjain, mint új ablakokban.
  • 50% -kal növeli a termelékenységet, és naponta több száz kattintással csökkenti az egér kattintását!
Comments (9)
No ratings yet. Be the first to rate!
This comment was minimized by the moderator on the site
How to loop this vba code (1000 rows for example) ?
This comment was minimized by the moderator on the site
Sorry for reply such late, but I do not understand your question, the VBA only for listing dates between a date range, why need to loop the code?
This comment was minimized by the moderator on the site
Firat - did you solve your issue? I have exactly the same issue and I cannot get the result in the row instead of the column.
This comment was minimized by the moderator on the site
If you invert this line you can make it work :


OutRng.Offset(ColIndex, 0) = i to OutRng.Offset(0, ColIndex) = i
This comment was minimized by the moderator on the site
Why do not try to transpose the column result to row?
This comment was minimized by the moderator on the site
i tried the VBA code it worked.. Thanks for sharing. Similarly is it possible to pase it along columns/ horizontally?
This comment was minimized by the moderator on the site
Hello, if you want to list dates in a row horizontally, you just need to use the vba code to list the dates, and copy the results and paste transpose.
This comment was minimized by the moderator on the site
Hello, Thanks for sharing a great code. I would like to ask one question though. I am using this VBA code you shared. 1) Can I list all the other cells in the same row with the dates? 2) Can we define the starting date cell and ending date cell and the cell that the new information will be written? I am asking these questions because I have 30 rows. Each row has data for different people. Cell G is a starting date and Cell H is an ending date. Other cells contains some information. I would like this to be listed in a new cell as all the dates between these cells. For example (just showing demonstration, so only G and H cells written below-I is where the list appears): Row 2 Person A 28/05/2017 05/06/2017 28/05/2017 Row 3 Person A 28/05/2017 05/06/2017 29/05/2017 Row 4 Person A 28/05/2017 05/06/2017 30/05/2017 Row 5 Person A 28/05/2017 05/06/2017 31/05/2017 Row 6 Person A 28/05/2017 05/06/2017 01/06/2017 Row 7 Person A 28/05/2017 05/06/2017 02/06/2017 Row 8 Person A 28/05/2017 05/06/2017 03/06/2017 Row 9 Person A 28/05/2017 05/06/2017 04/06/2017 Row 10 Person A 28/05/2017 05/06/2017 05/06/2017 Row 11 Person B 23/05/2017 31/05/2017 23/05/2017 Row 12 Person B 23/05/2017 31/05/2017 24/05/2017 Row 13 Person B 23/05/2017 31/05/2017 25/05/2017 Row 14 Person B 23/05/2017 31/05/2017 26/05/2017 and so on...
This comment was minimized by the moderator on the site
Can we use text box instead of in box in macro
There are no comments posted here yet
Please leave your comments in English
Posting as Guest
×
Rate this post:
0   Characters
Suggested Locations