Gå til hovedindhold

Hvordan dukker en kalender op, når du klikker på en bestemt celle i Excel?

Hvis vi antager, at der er et kolonneområde i et regneark, skal du ofte indtaste og ændre datoer inde, men det keder sig at indtaste eller ændre dato manuelt pr. Gang. Hvordan indtastes datoer hurtigt uden manuelt at skrive i kolonneområdet? Denne artikel taler om at poppe en kalender op, når du klikker på celler i et bestemt interval og derefter automatisk indsætte dato i den valgte celle efter valg af dato i kalenderen.


Pop op en kalender, når du klikker på en bestemt celle med VBA-kode

Løs dette problem som følger trin for trin.

Bemærk: Denne metode kan kun fungere på Microsoft Excel 32-bit.

Trin 1: Opret en UserForm med kalender

Opret en UserForm, der indeholder den kalender, du vil poppe op, ved at klikke på en celle.

1. Trykke andre + F11 taster samtidigt for at åbne Microsoft Visual Basic til applikationer vindue.

2. i Microsoft Visual Basic til applikationer vindue, skal du klikke på indsatte > Brugerformular.

3. Derefter a Brugerformular og en Værktøjskasse vinduer dukker op, i Værktøjskasse, klik på et hvilket som helst kontrolelement og højreklik, og vælg derefter Yderligere kontrolelementer fra højreklikmenuen. Se skærmbillede:

4. i Yderligere kontrolelementer dialogboksen, rul ned for at kontrollere Microsoft MonthView-kontrol valgmulighed i Tilgængelige kontroller og klik derefter på OK .

5. Så kan du se Månedsvisning knappen tilføjes i Værktøjskasse vindue. Klik på denne MonthView-knap, og klik derefter på UserForm1-vinduet for at oprette en kalender i brugerformularen.

Bemærk: Du kan justere størrelsen på UserForm-vinduet, så det passer til den indsatte kalender, ved at trække grænsen til UserForm.

6. Dobbeltklik på den indsatte kalender i UserForm1 og i Kode vindue, skal du udskifte den originale kode med følgende VBA-script.

VBA code: create a user form with calendar

Private Sub MonthView1_DateClick(ByVal DateClicked As Date)
 On Error Resume Next
   Dim xRg As Object
   For Each xRg In Selection.Cells
      xRg.Value = DateClicked
   Next xRg 
   Unload Me
End Sub

Bemærk: Denne kode kan hjælpe med at indsætte dato i den valgte celle efter at have valgt dato fra kalenderen.

Trin 2: Aktivér kalenderen, når du klikker på cellen

Nu skal du angive bestemte celler, der skal vises i kalenderen, når du klikker. Gør som følger.

7. Dobbeltklik på arknavnet, der indeholder de celler, du vil klikke på for at åbne kalenderen til venstre Projekt ruden, og kopier og indsæt derefter nedenstående VBA-kode i vinduet Kode. Se skærmbillede:

VBA code: Click cell to pop up calendar

Private Sub Worksheet_SelectionChange(ByVal Target As Range)
    If (Target.Count = 1) Then
    If Not Intersect(Target, Range("A2:A10")) Is Nothing Then UserForm1.Show
    End If
End Sub

Bemærk: i koden er A2: A10 celler, du vil klikke på for at åbne kalenderen. Skift celleområdet, som du har brug for.

8. Trykke andre + Q taster samtidigt for at lukke Microsoft Visual Basic til applikationer vindue.

Fra nu af, når der klikkes på en hvilken som helst celle inden for det angivne område i det aktuelle regneark, vises en kalender som vist nedenfor. Og dato indsættes automatisk i den valgte celle efter valg af dato fra kalenderen.


Pop op en kalender, når du klikker på en bestemt celle med VBA-kode

Dette afsnit introducerer Datovælger nytte af Kutools til Excel. Når du har aktiveret denne funktion, skal du klikke på en datocelle, der åbner en kalender, og du kan nemt erstatte den eksisterende dato med en ny dato med den. Følg nedenstående trin for at anvende denne funktion.

1. klik Kutools > Indhold > Aktivér datovælger.

2. Når du har aktiveret denne funktion, skal du klikke på en datocelle, så vises et kalenderikon lige til cellen.

3. Klik på kalenderikonet for at åbne Datovælger dialogboksen, og klik derefter på en ny dato for at erstatte datoen i den valgte celle.

Bemærkninger:

  • Fortryd-knap: Klik på denne knap for at fortryde udskiftningsdatoen;
  • Luk knap: Klik på denne knap for at lukke dialogboksen Datovælger;
  • Denne funktion kan kun gælde for celler, der indeholder dato.

  Hvis du vil have en gratis prøveperiode (30 dage) af dette værktøj, klik for at downloade det, og gå derefter til at anvende handlingen i henhold til ovenstående trin.


Relaterede artikler:

Bedste kontorproduktivitetsværktøjer

🤖 Kutools AI Aide: Revolutionér dataanalyse baseret på: Intelligent udførelse   |  Generer kode  |  Opret brugerdefinerede formler  |  Analyser data og generer diagrammer  |  Aktiver Kutools funktioner...
Populære funktioner: Find, fremhæv eller identificer dubletter   |  Slet tomme rækker   |  Kombiner kolonner eller celler uden at miste data   |   Runde uden formel ...
Super opslag: VLookup med flere kriterier    Multiple Value VLookup  |   VOpslag på tværs af flere ark   |   Fuzzy Lookup ....
Avanceret rulleliste: Opret hurtigt rulleliste   |  Afhængig rulleliste   |  Multivælg rulleliste ....
Column Manager: Tilføj et bestemt antal kolonner  |  Flyt kolonner  |  Skift synlighedsstatus for skjulte kolonner  |  Sammenlign områder og kolonner ...
Fremhævede funktioner: Grid fokus   |  Designvisning   |   Stor Formel Bar    Arbejdsbog & Ark Manager   |  Ressourcebibliotek (Autotekst)   |  Datovælger   |  Kombiner regneark   |  Krypter/Dekrypter celler    Send e-mails efter liste   |  Superfilter   |   Specielt filter (filter fed/kursiv/gennemstreget...) ...
Top 15 værktøjssæt12 tekst Værktøjer (tilføje tekst, Fjern tegn, ...)   |   50 + Chart Typer (Gantt kort, ...)   |   40+ Praktisk formler (Beregn alder baseret på fødselsdag, ...)   |   19 Indsættelse Værktøjer (Indsæt QR-kode, Indsæt billede fra sti, ...)   |   12 Konvertering Værktøjer (Tal til ord, Valutaomregning, ...)   |   7 Flet og del Værktøjer (Avancerede kombinere rækker, Opdel celler, ...)   |   ... og mere

Overlad dine Excel-færdigheder med Kutools til Excel, og oplev effektivitet som aldrig før. Kutools til Excel tilbyder over 300 avancerede funktioner for at øge produktiviteten og spare tid.  Klik her for at få den funktion, du har mest brug for...

Beskrivelse


Fanen Office bringer en grænseflade til et kontor med Office, og gør dit arbejde meget lettere

  • Aktiver redigering og læsning af faner i Word, Excel, PowerPoint, Publisher, Access, Visio og Project.
  • Åbn og opret flere dokumenter i nye faner i det samme vindue snarere end i nye vinduer.
  • Øger din produktivitet med 50 % og reducerer hundredvis af museklik for dig hver dag!
Comments (18)
No ratings yet. Be the first to rate!
This comment was minimized by the moderator on the site
I am not seeing the Microsoft MonthView Control in the listing, but it may be as Pete (#32847) mentioned that this will not work in Office 365 or 64-bit Microsoft Office.
This comment was minimized by the moderator on the site
Hi Teagan Caudle,
I searched and tried the methods suggested in google, but ultimately could not register the MonthView control in Microsoft 365.
Sorry for the inconvenience. Maybe you can check this out.
https://social.technet.microsoft.com/Forums/Azure/en-US/db3b4dff-aad7-4d88-87cc-8f3f117be550/microsoft-windows-common-controls-60-for-office-2016
This comment was minimized by the moderator on the site
There is no Microsoft MonthView Control listed (Office 365), and the directions here doesn't explain how one would get that control, so this is pretty much useless unless you're using an older version of Excel.
This comment was minimized by the moderator on the site
The calendar will show up but when I click on the date, the cell doesn't populate
This comment was minimized by the moderator on the site
Hi,
The code works well in my case. Which Excel version are you using?
This comment was minimized by the moderator on the site
Thank you so much! These directions were super useful :)
This comment was minimized by the moderator on the site
Hi, Is it possible to put the date picker pop-up for multiple column, as in my sheet I have "start date", "end date" and "agreement date". if yes then how?
This comment was minimized by the moderator on the site
Hi jeet,
Follow the steps and replace the range "A2:A10" in the second VBA code with your column range (such as C2:E2).
This comment was minimized by the moderator on the site
Salve il codice funziona benissimo, ma se volessi farlo funzionare anche su un altro foglio
This comment was minimized by the moderator on the site
if i try to select a row, the pop up will activate and the date appears in each cell in that row


how can i avoid this
This comment was minimized by the moderator on the site
Hi Sam,
The code has been updated in the article with the problem solving. Please have a try and thank you for your comment.
This comment was minimized by the moderator on the site
tarihi seçebiliyorum ama a1:a10 hücrelerine seçtiğim tarih eklenmiyor. teşekkür ederim
This comment was minimized by the moderator on the site
Hello everyone,

Can anyone tell me how to popup a calendar in a range of cells, but starting only from the cell right bellow a table header and down bellow in an excel column.


Thank you in advance.
This comment was minimized by the moderator on the site
Use i.e: Range("B6:C30")
This comment was minimized by the moderator on the site
Good Day,
Sorry I didn't got your question. Would be nice if you could provide screenshot of what you are trying to do.
This comment was minimized by the moderator on the site
Use i.e: Range("B6:C30")
This comment was minimized by the moderator on the site
i used these VBA codes and everthing's fine so far. The range is A2:A10 and calendar pops up when you select a cell into it. But if you mark row from 2 to 10 again the calendar pops again. It's the same with column "A" if you mark it, again the calendar pops. How should i proceed, in order to get the calendar only in the range i've defined?
There are no comments posted here yet
Load More
Please leave your comments in English
Posting as Guest
×
Rate this post:
0   Characters
Suggested Locations