小编win*_*cki的帖子

将整个工作表复制到Excel 2010中的新工作表

我发现类似的问题涉及在一个工作簿中复制整个工作表并将其粘贴到另一个工作簿,但我感兴趣的是简单地复制整个工作表并将其粘贴到新的工作表 - 在同一工作簿中.

我正在将2003 .xls文件转换为2010 .xlsm,并且用于在工作表之间复制和粘贴的旧方法不会粘贴正确的行高.我最初的解决方法是遍历每一行并从我正在复制的工作表中获取行高,然后循环并在我粘贴的工作表中插入行高的那些值,但这种方法的问题在于sheet包含生成新行的按钮,这些行更改行编号,并且工作表的格式使得所有行不能只是一个宽度.

我真正希望能够做的只是复制整个工作表并粘贴它.以下是2003版的代码:

ThisWorkbook.Worksheets("Master").Cells.Copy
newWorksheet.Paste
Run Code Online (Sandbox Code Playgroud)

我很惊讶转换为.xlsm导致现在破坏.任何建议或想法都会很棒.

excel vba excel-vba excel-2010

23
推荐指数
3
解决办法
30万
查看次数

在VBA中设置Collection的Item属性

我很惊讶这是多么艰难,但我想这是一个快速修复,所以我会在这里问(搜索谷歌和文档,但没有帮助).我有一些代码使用键将项添加到集合中.当我遇到集合中已存在的密钥时,我只想通过在当前值中添加一个数字来设置它.

这是代码:

If CollectionItemExists(aKey, aColl) Then 'If key already has a value
    'add value to existing item
    aColl(aKey).Item = aColl(aKey) + someValue
Else
    'add a new item to the collection (aka a new key/value pair)
    mwTable_ISO_DA.Add someValue, aKey
End If
Run Code Online (Sandbox Code Playgroud)

我第一次将键/值对添加到集合中时,我添加了一个整数作为值.当我再次遇到密钥时,我尝试向该值添加另一个整数,但这不起作用.我不认为问题在于任何类型的对象不匹配或类似的东西.我目前得到的错误信息是

运行时错误424:对象必需

vba

11
推荐指数
2
解决办法
2万
查看次数

从NSCFString获取NSString

我在周围阅读并对Google做了一点点但是我无法找到问题的答案......

我有一个NSDictionary返回NSCFString's,我需要的是一个NSString,以便我可以使用它的doubleValue函数.我不能为我的生活弄清楚如何把我NSCFString的变成NSStrings.我试过以下但没有成功:

NSString* lng_coord = (NSString*)[dict objectForKey:key];
            if ([lng_coord class] == [NSString class])
                NSLog(@"lng coord is an exact match with NSString class");
            else {
                NSLog(@"lng coord doesn't match NSString class");
                NSLog(@"The class of lng_coord is %@", [[dict objectForKey:key] class]);
            }
            NSLog(@"%@", lng_coord);
            [CelebsAnnotation setLongitude:[lng_coord doubleValue]];
Run Code Online (Sandbox Code Playgroud)

这是控制台的输出:

lng coord doesn't match NSString class
The class of lng_coord is NSCFString
49.2796758
Run Code Online (Sandbox Code Playgroud)

iphone casting objective-c ios

4
推荐指数
1
解决办法
6106
查看次数

为什么我不能将String变量传递给VBA的Range函数?

我正在尝试使用VBA在Excel中的Range上动态转置Recordset.当我给它一个静态范围时,我可以成功地进行换位:

Range("A1:C16").Select
Range("A1:C16").Value = Application.WorksheetFunction.Transpose(scores)
Run Code Online (Sandbox Code Playgroud)

但是,当我尝试使用等效字符串并将其传递给Range函数时,它会失败.打印出来时我的变量trange是"A1:C16"(包括双引号).我需要传递一个字符串的原因是因为字符串是从长度变量派生的,该变量可以是任何值.

以下代码失败:

Dim trange As String
trange = """A1:C" & slength & """"
MsgBox (trange)
Range(trange).Select
Range(trange).Value = Application.WorksheetFunction.Transpose(scores)
Run Code Online (Sandbox Code Playgroud)

不幸的是,在VBA转义双引号是丑陋的,这就是为什么我TRANGE赋值表达式看起来很奇怪,但是当我MSGBOX它,它实际上是在给我正确的值.

excel vba excel-vba

2
推荐指数
2
解决办法
4万
查看次数

标签 统计

vba ×3

excel ×2

excel-vba ×2

casting ×1

excel-2010 ×1

ios ×1

iphone ×1

objective-c ×1