循环遍历范围:Cell.Value方法中的单元格

时间:2018-07-09 16:53:41

标签: excel vba

import React, { Component } from 'react';
import './css/App.css';
import './css/Custom.css';
import NeighborhoodMap from './neighborhoodMap';
import 'typeface-roboto';
import escapeRegEx from 'escape-string-regexp';
import update from 'immutability-helper';

class App extends Component {

    state = {

  locations : [
      {
      position: {lat: 41.3029876, lng: -72.9191306},
      title: "Pepe's Pizza",
      mappy: '',
      infoWindowStatus: false,
      key : 0,
      infoWindow :
          {
            content : "Loading...",
            contentUrl : ""
          }
      }
    ]
}


// TODO: separate data into external data file.

componentDidMount(){


this.setState({
    filteredLocationsOnly : this.state.locations
  })
}

// Launches Info Window on Google Map
showInfoWindowNow(locationSelected){
    let myKey;

    this.state.locations.filter( (location) =>{
       if (locationSelected.name === location.title || locationSelected.title === location.title){
         myKey = location.key;
         return location
       }
    } );
    this.updateInfoWindowContentAgain(myKey);


// // THIS CODE DOES NOT WORK AT ALL
// this.setState({ locations[myKey].infoWindowStatus : true })


// // THIS CODE DOESN'T SHOW THE INFO WINDOW
// console.log("Status: ", this.state.locations[myKey].infoWindowStatus);
// const tempLocations = [...this.state.locations];
// tempLocations[myKey] = { ...tempLocations[myKey], infoWindowStatus: true };
//
//  this.setState(
//        {
//          locations: tempLocations
//        }
//  );
// console.log("Status Now: ", this.state.locations[myKey].infoWindowStatus);


// THIS DODGEY CODE WORKS
// https://stackoverflow.com/questions/51250518

this.state.locations[myKey].infoWindowStatus = true;
this.forceUpdate()


} //showInfoWindowNow


// Close Info Window on Google Map
closeInfoWindowNow(locationSelected){
  this.forceUpdate()
}

// Update Content for Info Window
updateInfoWindowContentAgain(myKey){
  return this.getInfoWindowContent(this.state.locations[myKey].title, myKey);
}

// Update Content for Info Window sub-function
getInfoWindowContent(searchTerm, myKey){
var nytAuthKey = "3d6801dab968446787ea71d5042ad8f7";
var myNewYorkTimesUrl = `https://api.nytimes.com/svc/search/v2/articlesearch.json?&api-key=${nytAuthKey}&q=${searchTerm}`

var contentForLocation;
var contentUrl;

let content = fetch(myNewYorkTimesUrl)
  .then(response => response.json() )
    .then(data => {
        return addArticles(data);
  }
 )
 .catch(error => requestError(error, 'articles'));

// add text from fetch request
function addArticles(data){
  if (data.response && data.response.docs && data.response.docs.length > 1){
    const articles = data.response.docs;
    // var content, contentUrl;
    let infoWindow  = {};

      articles.map(article => {
          infoWindow.content = `${article.snippet}`;
          infoWindow.contentUrl = `${article.web_url}`;
          contentForLocation = `${article.snippet}`;
          contentUrl = `${article.web_url}`;
          return infoWindow;
    });
  }
}  //addArticles


// Handle Errors
function requestError(error, part) {
   console.log("Error: ", error);
}


content.then( content => {
  this.state.locations[myKey].infoWindow.content = (contentForLocation);
  this.state.locations[myKey].infoWindow.contentUrl = contentUrl;
  this.forceUpdate()
}


)} // getInfoWindowContent
// end Nyt


filterLocations(query){
  const match = new RegExp(escapeRegEx(query), 'i')
  let showingLocations = this.state.locations.filter((location) => {
    return match.test(location.title);
  });

  this.setState({
    filteredLocationsOnly : showingLocations
  })
}  // end filterLocations

clearQuery = () => {
        this.setState({query : ''});

}

updateQuery = (query) => {
          this.setState({query : query.trim()})
          this.filterLocations(query);
}


render() {
 return (
  <div className="App">
        <NeighborhoodMap
        menuOpen = {this.state.menuOpen}
        locations = {this.state.locations}
        filteredLocationsOnly = {this.state.filteredLocationsOnly}
        query = {this.state.query}
        updateQuery = { (query) => {
          this.updateQuery(query)
        }}
        clearQuery = { () => {
          this.clearQuery()
        }}
        filterLocations = { (query) => {
          this.filterLocations(query)
        }}

        infoWindowStatus = {this.state.infoWindowStatus}
        showInfoWindowNow = { (location) => {
          this.showInfoWindowNow(location)
        }}
        closeInfoWindowNow = { (location) => {
          this.closeInfoWindowNow(location)
        }}
        updateInfoWindowContentAgain = { (id) => {
          this.updateInfoWindowContentAgain(id)
        }}
        infoWindow = {this.state.infoWindow}
        />
   </div>

    ) // return
  }// render
} // Component

export default App;

我有上面的代码可以遍历某个范围内的单元格。 Stats.address返回“ $ AT $ 45:$ AT $ 76”,并且这些单元格中的值为0或“常规”格式的另一个整数。我遇到的问题是cell.Value方法。当我将其放入MsgBox时,它将返回空白。当我使用

指定单元格时
For Each cell In stats
    If cell.Value > 0 Then
    Call WriteStatistic(cell)
End If

它返回单元格中的数字。同样有趣的是:当我在该循环中调用cell.address时,它成功返回了单元格地址。有什么我忘记的事情吗?我已经将cell声明为Range对象,并且它仍然会这样做。

0 个答案:

没有答案