Reply
 
LinkBack Thread Tools Search this Thread Display Modes
  #1   Report Post  
Posted to microsoft.public.excel.programming
external usenet poster
 
Posts: 276
Default Modify to do to each required cell

I have the below code that i made to change a the cell to the right to FontStrikeThrough IF the value to in tyhe cell was empty.
If it was not empty then the cell would Not be StrikeThrough

EG: The (6) in Cell D1 would be StrikeThrough as there is No value in C1.
The (5) is Normal Font as there IS a value in A1.

A B C D E F
1 10 5 6
2


I need to add to the below so it does the same to all these cells listed:
C100,E100,G100,I100..... AQ100
(Basically every 2nd Cell from C100 - AQ100)
How can i do this besides putting every cell in individually and running the code each time ?

~~~~~~~~~~~~~~~~~~~~~
Sub StrikeThrough()
With ActiveCell
If ActiveCell.Value = "" Then
ActiveCell.Offset(0, 1).Activate
With Selection.Font
.Strikethrough = True
End With
Else
ActiveCell.Offset(0, 1).Activate
With Selection.Font
.Strikethrough = False
End With
End If
End With
End
~~~~~~~~~~~~~~~~~~~~
--
Corey ....
The Silliest Question is generally
the one i forgot to ask.
  #2   Report Post  
Posted to microsoft.public.excel.programming
external usenet poster
 
Posts: 276
Default Modify to do to each required cell

If i can get the same code to RUN 48 times then stop, that would solve it too?

"Corey" wrote in message ...
I have the below code that i made to change a the cell to the right to FontStrikeThrough IF the value to in tyhe cell was empty.
If it was not empty then the cell would Not be StrikeThrough

EG: The (6) in Cell D1 would be StrikeThrough as there is No value in C1.
The (5) is Normal Font as there IS a value in A1.

A B C D E F
1 10 5 6
2


I need to add to the below so it does the same to all these cells listed:
C100,E100,G100,I100..... AQ100
(Basically every 2nd Cell from C100 - AQ100)
How can i do this besides putting every cell in individually and running the code each time ?

~~~~~~~~~~~~~~~~~~~~~
Sub StrikeThrough()
With ActiveCell
If ActiveCell.Value = "" Then
ActiveCell.Offset(0, 1).Activate
With Selection.Font
.Strikethrough = True
End With
Else
ActiveCell.Offset(0, 1).Activate
With Selection.Font
.Strikethrough = False
End With
End If
End With
End
~~~~~~~~~~~~~~~~~~~~
--
Corey ....
The Silliest Question is generally
the one i forgot to ask.
  #3   Report Post  
Posted to microsoft.public.excel.programming
external usenet poster
 
Posts: 9,101
Default Modify to do to each required cell

I'm not sure if you are starting in column C or D because of the offset in
your code (0,1). Change start and end column as required.

Sub StrikeThrough()
For ColCount = Range("C100").column to Range("AQ100").column step 2
with Cells(100,ColCount)
If .Value = "" Then
.Font.Strikethrough = True
Else
.Font.Strikethrough = False
End If
End With
End


"Corey" wrote:

I have the below code that i made to change a the cell to the right to FontStrikeThrough IF the value to in tyhe cell was empty.
If it was not empty then the cell would Not be StrikeThrough

EG: The (6) in Cell D1 would be StrikeThrough as there is No value in C1.
The (5) is Normal Font as there IS a value in A1.

A B C D E F
1 10 5 6
2


I need to add to the below so it does the same to all these cells listed:
C100,E100,G100,I100..... AQ100
(Basically every 2nd Cell from C100 - AQ100)
How can i do this besides putting every cell in individually and running the code each time ?

~~~~~~~~~~~~~~~~~~~~~
Sub StrikeThrough()
With ActiveCell
If ActiveCell.Value = "" Then
ActiveCell.Offset(0, 1).Activate
With Selection.Font
.Strikethrough = True
End With
Else
ActiveCell.Offset(0, 1).Activate
With Selection.Font
.Strikethrough = False
End With
End If
End With
End
~~~~~~~~~~~~~~~~~~~~
--
Corey ....
The Silliest Question is generally
the one i forgot to ask

  #4   Report Post  
Posted to microsoft.public.excel.programming
external usenet poster
 
Posts: 276
Default Modify to do to each required cell

Ended up placing the work STOP in Cell AS100 and using :

Do
With ActiveCell
If ActiveCell.Value = "" Then
ActiveCell.Offset(0, 1).Activate
With Selection.Font
.Strikethrough = True
End With
Else
ActiveCell.Offset(0, 1).Activate
With Selection.Font
.Strikethrough = False
End With
End If
End With
ActiveCell.Offset(0, 1).Activate
Loop Until ActiveCell.Value = "STOP"


Corey....

"Joel" wrote in message
...
I'm not sure if you are starting in column C or D because of the offset in
your code (0,1). Change start and end column as required.

Sub StrikeThrough()
For ColCount = Range("C100").column to Range("AQ100").column step 2
with Cells(100,ColCount)
If .Value = "" Then
.Font.Strikethrough = True
Else
.Font.Strikethrough = False
End If
End With
End


"Corey" wrote:

I have the below code that i made to change a the cell to the right to
FontStrikeThrough IF the value to in tyhe cell was empty.
If it was not empty then the cell would Not be StrikeThrough

EG: The (6) in Cell D1 would be StrikeThrough as there is No value in C1.
The (5) is Normal Font as there IS a value in A1.

A B C D E F
1 10 5 6
2


I need to add to the below so it does the same to all these cells listed:
C100,E100,G100,I100..... AQ100
(Basically every 2nd Cell from C100 - AQ100)
How can i do this besides putting every cell in individually and running
the code each time ?

~~~~~~~~~~~~~~~~~~~~~
Sub StrikeThrough()
With ActiveCell
If ActiveCell.Value = "" Then
ActiveCell.Offset(0, 1).Activate
With Selection.Font
.Strikethrough = True
End With
Else
ActiveCell.Offset(0, 1).Activate
With Selection.Font
.Strikethrough = False
End With
End If
End With
End
~~~~~~~~~~~~~~~~~~~~
--
Corey ....
The Silliest Question is generally
the one i forgot to ask



  #5   Report Post  
Posted to microsoft.public.excel.programming
external usenet poster
 
Posts: 14
Default Modify to do to each required cell

On Sep 9, 2:49*pm, "Corey" wrote:
Ended up placing the work STOP in Cell AS100 and using :

Do
* *With ActiveCell
* * If ActiveCell.Value = "" Then
* * * * ActiveCell.Offset(0, 1).Activate
* * * * With Selection.Font
* * * * .Strikethrough = True
* * * * End With
* * * * Else
* * * * ActiveCell.Offset(0, 1).Activate
* * * * With Selection.Font
* * * * .Strikethrough = False
* * * * End With
* * * * End If
* * * * End With
* * * * ActiveCell.Offset(0, 1).Activate
* * Loop Until ActiveCell.Value = "STOP"

Corey....

"Joel" wrote in message

...



I'm not sure if you are starting in column C or D because of the offset in
your code (0,1). *Change start and end column as required.


Sub StrikeThrough()
* For ColCount = Range("C100").column to Range("AQ100").column step 2
* * *with Cells(100,ColCount)
* * * * *If .Value = "" Then
* * * * * * * *.Font.Strikethrough = True
* * * * *Else
* * * * * * * *.Font.Strikethrough = False
* * * * *End If
* *End With
End


"Corey" wrote:


I have the below code that i made to change a the cell to the right to
FontStrikeThrough IF *the value to in tyhe cell was empty.
If it was not empty then the cell would Not be StrikeThrough


EG: The (6) in Cell D1 would be StrikeThrough as there is No value in C1.
* * The (5) is Normal Font as there IS a value in A1.


* * * * A * * * *B * * * *C * * * *D * * * *E * * * *F
1 * *10 * * * *5 * * * * * * * * * *6
2


I need to add to the below so it does the same to all these cells listed:
C100,E100,G100,I100..... AQ100
(Basically every 2nd Cell from C100 - AQ100)
How can i do this besides putting every cell in individually and running
the code each time ?


~~~~~~~~~~~~~~~~~~~~~
Sub StrikeThrough()
* * With ActiveCell
* * If ActiveCell.Value = "" Then
* * * * ActiveCell.Offset(0, 1).Activate
* * * * With Selection.Font
* * * * .Strikethrough = True
* * * * End With
* * * * Else
* * * * ActiveCell.Offset(0, 1).Activate
* * * * With Selection.Font
* * * * .Strikethrough = False
* * * * End With
* * * * End If
* * End With
End
~~~~~~~~~~~~~~~~~~~~
--
Corey ....
The Silliest Question is generally
*the one i forgot to ask- Hide quoted text -


- Show quoted text -


Im not sure what you are trying to acheive, but if you would like
these cells to update dynamically you should use "Conditional
Formating".
Select the LEFT-MOST (cell eg. A2) that you want to behave in this way
ie. If cell to left = "" then this cell value should be displayed with
a strike through.
Go to FormatConditional Formating on the excel toobar.
Then change the drop down on the left to "FormulaIs" and then enter
the following formula in the box to the right (its like a RefEdit
control)" =A1=""
Instead of "A1" put the actual cell address for the cell to the left
of the cell you want. Do not use the $ sign in this case.
Press ok.
Test the formatting by placing and removing a value in the A1 cell.
If it works then select the A2 cell and click and hold the mouse down
on the bottom right hand corner and drag the cell as far to the right/
down as you want.
If you're using Excel 2003 then you should see a "Smart tag" to the
right of the range you have just filled over, click this and select
"Fill Formatting Only"
I hope this helps, I may have misunderstood what you are trying to do.
But this will update on the fly, ie. you wont have to run the macro
each time the cell values change...
Bernie
Reply
Thread Tools Search this Thread
Search this Thread:

Advanced Search
Display Modes

Posting Rules

Smilies are On
[IMG] code is On
HTML code is Off
Trackbacks are On
Pingbacks are On
Refbacks are On


Similar Threads
Thread Thread Starter Forum Replies Last Post
Modify each cell in selection Clayman Excel Programming 3 August 11th 08 08:51 PM
How do I modify Cell Comments from VBA? MikeZz Excel Programming 2 April 13th 07 09:56 PM
Modify a cell Vern Excel Discussion (Misc queries) 0 January 19th 07 08:51 PM
Modify Cell sizes Louanne Excel Worksheet Functions 3 December 31st 05 05:02 PM
How can I modify the color of a cell? James Prontier Excel Programming 3 January 10th 04 07:51 PM


All times are GMT +1. The time now is 12:45 PM.

Powered by vBulletin® Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
Copyright ©2004-2025 ExcelBanter.
The comments are property of their posters.
 

About Us

"It's about Microsoft Excel"